PSR Series/1 


GA34-0024-1 
File No. S1-07 


IBM Series/1 
4962 Disk Storage Unit and 
4964 Diskette Unit 
Description 


O 


DISK AND DISKETTE DESCRIPTION 





Second Edition (March 1977) 


This is a major revision of, and obsoletes not only GA34-0024-0 but also Series/1 4964 Diskette Unit 
Description, GA34-0023-0. Significant changes in this new edition include: the addition of 

Chapter 4, ‘“‘Programming Diskette Operations,” and restructuring of Chapters 1 and 2 to include 
diskette unit information previously presented in GA34-0023-0. 


Changes are periodically made to the information herein; any such changes will be reported in 
subsequent revisions or Technical Newsletters. Before using this publication in connection with the 
operation of IBM systems, have your IBM representative confirm editions that are applicable and 
current. 


Requests for copies of IBM publications should be made to your IBM representative or the IBM 
branch office serving your locality. 


A form for readers’ comments is provided at the back of this publication. If the form has been 
removed, send your comments to IBM Corporation, Systems Publications, Department 27T, 
P.O. Box 1328, Boca Raton, Florida 33432. Comments become the property of IBM. 


©Copyright International Business Machines Corporation 1976, 1977 


ii GA34-0024 


Preface v 
Prerequisite Publications v 
Related Publications v 


Chapter 1. IBM Series/1 4962 Disk Storage Unit and 4964 
Diskette Unit 1-1 

Introduction 1-1 

IBM 4962 Disk Storage Unit 1-1 
Models 1-1 

IBM 4964 Diskette Unit 1-2 
Models 1-2 

Basic Data Exchange 1-2 

Disk Specifications 1-3 

Diskette Specifications 1-3 

Disk/Diskette Attachments 1-3 

Operator Controls 1-3 


Chapter 2. Disk/Diskette Data Format 2-1 
Disk Surface Format 2-1 
Servo Tracks 2-1 

Data Tracks 2-1 
Cylinders 2-2 
Sectors 2-2 
Diskette 2-3 
Diskette Surface Format 2-4 
Cylinders 2-4 
Index 2-4 
Tracks 2-4 
Sectors 2-5 


Chapter 3. Programming Disk Operations 3-1 
Data Transfer Operations 3-1 
Direct Program Control (DPC) 3-1 
Cycle Steal (CS) Mode 3-1 
Initiating a Disk Operation 3-1 
Operate I/O Instruction 3-1 
Using the IDCB 3-1 
1/O Commands and Disk Operations 3-2 
Command Execution Under Direct Program Control 3-3 
Prepare Command 3-3 
Device Reset Command 3-4 
Read Device ID Command 3-4 
Command Execution in CS Mode 3-4 
Using the DCB 3-6 
DCB Control Word (DCB Word 0) 3-6 
Seek Control Word (DCB Word 1) 3-6 
Physical Sector Count and Flag (DCB Word 2) 3-7 
Cylinder Address (DCB Word 3) 3-7 
Head Selection and Sector Number (DCB Word 4) 3-7 
Chain Address (DCB Word 5) 3-8 
Byte Count (DCB Word 6) 3-8 
Data Address (DCB Word 7) 3-8 
DCB Command Chaining 3-8 
Start Command 3-9 
Programming Considerations 3-10 
Seek Operation 3-10 
Seek Recalibrate Operation 3-11 
Read Data Operation 3-11 
Write Data Operation 3-12 


Page of GA34-0024-1 


As updated October 19, 1977 


By TNL GN34-0406 


Contents 


Read Verify Operation 3-12 

Write SectorID Operation 3-13 

Read Sector ID Operation 3-13 

Write Sector ID Skewed Operation 3-14 
Read Sector ID Skewed Operation 3-14 
Read Diagnostic Operation 3-15 


| Immediate ID Operations 3-15 


Start Cycle Steal Status Command 3-16 
Programming Considerations 3-16.1 
Status Information 3-16.1 
Condition Codes 3-16.1 
Interrupt ID Word 3-17 
Cycle Steal Status Words 3-19 
I/O Interrupts 3-19 
End-of-Operation Interrupts 3-20 
Attention Interrupts 3-20 
Resets (Disk) 3-20 
Initial Program Load (IPL) 3-20 
Data Security 3-21 


Chapter 4. Programming Diskette Operations 4-1 
Data Transfer Operations 4-1 
Direct Program Control (DPC) 4-1 
Cycle Steal (CS) 4-1 
Initiating a Diskette Operation 4-1 
Operate 1/O Instruction 4-1 
Using the IDCB 4-1 
I/O Commands and Diskette Operations 4-2 
Command Execution Under Direct Program Control 4-3 
Prepare Command 4-3 
Device Reset Command 4-4 
Read Device ID Command 44 
Command Execution inCS Mode 4-4 
Using the DCB 4-6 
DCB Control Word (DCB Word 0) 4-6 
Seek Control Word (DCB Word 1) 4-6 
Format Data Word (DCB Word 2) 4-7 
Sector Length and Cylinder (DCB Word 3) 4-7 
Head Selection and Sector Number (DCB Word 4) 4-7 
Chain Address (DCB Word 5) 4-8 
Byte Count (DCB Word 6) 4-8 
Data Address (DCB Word 7) 4-8 
DCB Command Chaining 4-8 
Start Command 4-9 
Programming Considerations 4-9 
Seek Operation 4-10 
Seek Recalibrate Operation 4-10 
Write Data/Data AM Operation 4-11 
Write Data/Control AM Operation 4-12 
Read Verify Operation 4-12 
Read Data Operation 4-13 
Read Sector ID Operation 4-13 
Format Track Operation 4-14 
Start Cycle Steal Status Command 4-15 
Programming Considerations 4-15 
StatusInformation 4-16 
Condition Codes 4-16 
Interrupt ID Word 4-16 
Cycle Steal Status Information 4-19 
I/O Interrupts 4-19 


Contents 


ili 


End-of-Operation Interrupts 4-20 
Attention Interrupt 4-20 

Resets (Diskette) 4-20 

Initial Program Load (IPL) 4-20 


Index X-l 


iv GA34-0024 


This manual is intended for those interested in the physical 
characteristics and operation of either the IBM Series/1 
4962 Disk Storage Unit or the 4964 Diskette Unit. It 
assumes the reader understands data processing terminology 
and is familiar with binary and hexadecimal numbering 
systems. The manual contains the machine code information 
required to plan, correct, and modify programs written in 
the assembler language. 

Chapter 1, “IBM Series/1 4962 Disk Storage Unit and 
4964 Diskette Unit,” describes the characteristics and 
capacities of disk and diskette units and the functions of 
Series/1 4962/4964 Attachment Features. 

Chapter 2, “Disk and Diskette Data Format,” describes 
how data is arranged on the disk and diskette surfaces. 

Chapter 3, “Programming Disk Operations,” describes 
the instructions and control blocks required to execute 
input/output operations on the disk unit. This chapter 
also contains disk unit status and interrupt information. 

Chapter 4, “Programming Diskette Operations,” describes 
the instructions and control blocks required to execute 
input/output operations on the diskette unit. This chapter 
also contains diskette unit status and interrupt information. 
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Chapter 1. IBM Series/1 4962 Disk Storage Unit and 4964 Diskette Unit 


Introduction 

The IBM Series/1 4962 Disk Storage Unit and 4964 
Diskette Unit are direct access storage devices designed for 
use with IBM Series/1 processors. 


IBM 4962 Disk Storage Unit 
The 4962 Disk Storage Unit consists of a fixed disk and 
access mechanism, the disk drive electronics that retrieve 
and record data on the disk, and the cables that connect 
the disk storage unit to an IBM Series/1 processor 
attachment. 

The disk and access mechanism are sealed in an enclosure 
that: 


@ eliminates operator handling 
@ reduces exposure to external contaminants 
e@ eliminates preventive maintenance 


Models 


| Six models of the 4962 Disk Storage Unit are available. 
All models have Initial Program Load (IPL) capability and 
can be mounted in either an Electronic Industries 
Association rack (RS-310B) or an IBM 4997 Model 1 or 
Model 2 Rack Enclosure. 
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‘Model 1/1F/3 Model 2/2F/4 


IBM 4962 Disk Storage Unit 
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Model I contains a fixed disk with a maximum formatted 
storage capacity of 9,308,160 bytes. The disk is accessed 
by two movable heads. 

Model IF contains a fixed disk that is accessed by two 
movable heads and eight fixed heads. Maximum formatted 
storage capacity is 9,308,160 bytes for the movable heads 
and 122,880 bytes for the fixed heads. 

Model 2 isa combination disk and diskette unit that 
contains: 


e A fixed disk with a maximum formatted storage 
capacity of 9,308,160 bytes. The disk is accessed by two 
movable heads. 

e A removable diskette with a maximum formatted 
storage capacity of 606,208 bytes (512-byte sectors). 
The diskette is accessed by two movable heads. 


Model 2F is a combination disk and diskette unit that 
contains: 


e A fixed disk that is accessed by two movable heads and 
eight fixed heads. Maximum formatted storage capacity 
is 9,308,160 bytes for the movable heads and 122,880 
bytes for the fixed heads. 

e Aremovable diskette with a maximum formatted 
storage capacity of 606,208 bytes (512-byte sectors). 
The diskette is accessed by two movable heads. 


Model 3 contains a fixed disk with a maximum formatted 
storage capacity of 13,962,240 bytes. The disk is accessed 
by three movable heads. 

Model 4 is a combination disk and diskette unit that 
contains: 


e A fixed disk with a maximum formatted storage 
capacity of 13,962,240 bytes. The disk is accessed by 
three movable heads. 

e Aremovable diskette with a maximum formatted 
storage capacity of 606,208 bytes (512—byte sectors). 
The diskette is accessed by two movable heads. 


Disk units in all models of the 4962 are functionally identical 
and can be designated as either the primary or alternate system 
IPL device. The diskette unit in the 4962 Model 2, 2F, and 
4 is functionally identical to the 4964 Diskette Unit. Each. 
disk and diskette unit, alone or combined, attaches to 
individual Series/1 attachments that allow totally indepen- 
dent and fully overlapped operation. 


IBM 4964 Diskette Unit 


The 4964 Diskette Unit retrieves and records data on remov- 
able one-sided or two-sided magnetic diskettes. The unit 
consists of an access mechanism, the diskette drive electronics 
that record and retrieve data on the diskette and a single cable 
for connecting the diskette unit to an IBM Series/1 processor 
attachment. 
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IBM 4964 Diskette Unit 





Model 1 


Models 


One model of the 4964 Diskette Unit is available. The 4964 
Model | has Initial Program Load (IPL) capability. It can 
be designated as either the primary or alternate system 
IPL device. The unit has two movable heads for reading 
and writing data. An IBM Diskette 2 (two-sided diskette) 
recorded in 512-byte sector format provides maximum 
storage capacity (606,208 bytes). An IBM Diskette 1 (one- 
sided diskette) recorded in 128-byte format provides Basic 
Data Exchange. 

The diskette unit mounts in one-half the width of an 
Electronic Industries Association rack (RS-310B) or an IBM 
4997 Model 1 or Model 2 Rack Enclosure. 


Basic Data Exchange 


An IBM 4964 Diskette Unit and Attachment Feature con- 
nected to a Series/1 processor can exchange diskette data 
with the following IBM devices using a one-sided diskette 
recorded in basic data exchange format (128-byte sector 
format): 


IBM 3540 Diskette Input/Output Unit 

IBM 3741 Data Station 

IBM 3742 Dual Data Station 

IBM 3747 Data Converter 

IBM 3773/3774/3775/3776 Communication Terminals 
IBM 3881 Optical Mark Reader, Model 3 

IBM 3890 Document Processor 

IBM 5231 Controller, Model 2 

IBM 5320 System Unit—System/32 


Disk Specifications 
- The functional specifications of the disk unit are: 


Rotational speed 2964 + 3% RPM 


Time of rotation 20.2 ms 
Average rotational delay or 
latency 10.1 ms (nominal) 
Data Transfer Rate 
To or from channel* 380,000 bytes/sec 
On and off disk 
(instantaneous) 889,000 bytes/sec 
Movable Head Storage 
Sectors per track 60 
Bytes per sector 256 
Bytes per track 15,360 
Tracks per cylinder 
Models 1, 1F, 2, 2F 2 
Models 3, 4 3 
Bytes per cylinder 
Models 1, 1F, 2, 2F 30,720 
Models 3, 4 46,080 
Cylinders 303 
Total Storage Capacity 
Models 1, 1F, 2, 2F 9,308,160 bytes 
Models 3, 4 13,962,240 bytes 
Access Times 
Cylinder to cylinder 10 ms (maximum) 


Average seek (101 cylinders) 40 ms (maximum) 


Fixed Head Storage 


Number of heads 8 

Sectors per track 60 

Bytes per sector 256 

Bytes per track 15,360 

Total storage capacity 122,880 bytes 


*Time average for multiple sector transfers over two rotations of the 
disk. 


Diskette Specifications 


The functional specifications of the IBM 4964 Diskette Unit 
and the diskette unit included with 4962 Models 2, 2F, and ~ 
4 are: 


Maximum data storage capacity 


(formatted with 512-byte sectors) 606 kilobytes 
Data transfer rate 31.2 kilobytes/sec 
Data tracks/diskette surface 74 tracks 
Rotational speed 360 RPM . 
Latency 83.8 milliseconds 
Track-to-track access time* 40 milliseconds 


*Derived from: 
T (number of track crossing x 5 ms) + (35 ms settling time) 


Diskette data tracks contain either 128, 256, or 512-byte 
sectors. Refer to “Format Track Operation” in Chapter 4. 
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128 Bytes 
Per Sector 


256 Bytes 
Per Sector 


512 Bytes 
Per Sector 


IBM 246,2721 284,160 303,104 - 
Diskette 1 , 


IBM 
Diskette 2 





492,544 606,208 


1The basic data exchange format for an IBM Diskette 1. 
2Preinitialized format of an IBM Diskette 2. 


Disk/Diskette Attachments 


IBM Series/1 processor attachment features used with the 
4962 and 4964 units: 


@ interpret and control execution of commands . 

@ provide the path for data between the channel and the 
disk/diskette 

@ serialize and deserialize data 

furnish status information to the channel 

@ check the accuracy of data transferred to and from the 
channel 

e@ check sector buffer parity (disk attachment only) 

@ perform a Cyclic Redundancy Check (CRC) of each 
data field and sector ID transferred to or from the 
disk/diskette 


A 1024-byte buffer is used in every I/O operation that 
transfers data to or from the disk. Buffering sectors of 
data eliminates the possibility of overrunning the channel. 


Note. Diskette data is not buffered. 


Attachment feature cards for the disk and diskette units 
plug into feature card slots in the IBM Series/1 processor 
card file or the IBM Series/1 4959 Input/Output Expansion 
Unit. 


Operator Controls 


A Power On/Off switch and Power On indicator are located 
on the front panel of the 4962 and 4964 units. 


1. Power switch. Power is applied to the disk/diskette 
unit when this switch is placed in the ON position. 
Nominally, 16 seconds after power is applied the disk 
unit is ‘ready’ for operations. 

2. Power On indicator. This light indicates the power 
switch is in the ON position. 

3. Diskette access door. This door must be closed and 
latched after inserting or removing a diskette. 
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This chapter describes how data is arranged or formatted 
on the disk and diskette. Cylinder, track, and sector 
descriptions are included for both the disk and diskette. 


The functions of the diskette index hole are also explained. 


Disk Surface Format 
On all models of the 4962, one side of the disk is divided 
into two data bands; the inner band is accessed by head 0, 
and the outer band by head 1. Each band contains a head 
landing zone (LZ) and 303 data tracks. A band of 303 
factory written servo tracks on the other side of the disk 
is used for tracking and seeking. 

On 4962 Models 1 F, 2F, 3, and 4, a third band of data is 
located on the servo-track side of the disk. Models 1F and 


2F have an eight-track band that is accessed by fixed heads, 


and Models 3 and 4 have a 303-track band that is accessed 
by a third movable head. See Figure 2-1. 


Cylinder 302 


I ct Cylinder 000 


Hub 


















Models 
land2 

Cylinder 302 

[ Cylinder 000 

000 302 000 Hub 
1F and 2F 
Cylinder 302 
Cylinder 000 

302 000 302 000 
Models 
3 and 4 


ef oe [| 
302 000 


LZ = landing zone for movable heads 


Figure 2-1. IBM 4962 disk surface format 
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Chapter 2. Disk/Diskette Data Format 


Note. To insure data integrity, data under the fixed heads 
should be refreshed after each power-on. The IBM Series/1 
Realtime Programming System relieves the user of this 
responsibility. 


Servo Tracks 

Factory written servo tracks assure precise head position- 
ing. Combinations of timing and position pulses define the 
beginning of each track and sector. 


Data Tracks 

Data tracks accessed by the movable read/write heads are 
numbered 000 to 302. Each track is divided into sixty, 
256-byte, fixed length sectors. Individual track capacity 
is 15,360 data bytes. 








Data head 0 Data head 1 
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Cylinders 
A cylinder consists of two tracks, one in each data band 


accessed by the movable heads. See Figure 2-1. Cylinder 000 


is located toward the center of the disk, and cylinder 302 is 
located toward the outer edge of the disk. Two of the 303 
cylinders are reserved; cylinder 001 is reserved for alternate 
sectors, and cylinder 302 is reserved for maintenance 

use. 


Sectors 


The sector is the addressable unit on the disk surface. Each 
sector consists of an identification field (sector ID) and a 
256-byte data field. Before accessing the data field, the 
sector ID is read to verify that the correct sector has been 
found. Sectors on the disk are numbered 00, 30,01,31... 
28, 58, 29, 59 to allow recovery time between writing a 
data field and reading the next sector ID. See Figure 2-2. 
For programming purposes the sectors can be considered 
consecutively numbered. For example, moving from sector 
06 to sector 07 is a shift of one sector. 

Records are stored in the data portions of sectors. If a 
record is less than 256 bytes, the remainder of the sector 
is padded with binary zeros before the data field CRC is 
written. If a record is longer than 256 bytes, it is written 
over as many sectors as its length requires. Records must 
not exceed track capacity (60 sectors). 


D>, 


Sector ID Field Format 


The sector ID field is seven bytes in length. Each sector 
on the disk has a unique ID field. The ID field has the 
following format: 


: ae) 3 4 5 6 7 
Cylinder addr | Head addr CRC bytes 


where: 


flag indicates the disk surface condition for the 
sector 


cylinder address indicates the cylinder on which the sector is 


located 


head address indicates the head used to access the sector 


sector address indicates the number of the sector on the track 


CRC indicates the cyclic redundancy check bytes 
calculated and written for the sector ID field. 
CRC bytes are also written for the data field 
after the data area. The CRC bytes are recal- 
culated each time information is read from the 
disk and compared with the CRC bytes written 
previously. An unequal comparison sets error 
indicators. 


Further information on specifying the fields in the 
sector ID can be found under “Using the DCB” in 
Chapter 3. 


~ eo fn anos is) Es 
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Time 


Figure 2-2. Sector numbering 
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Diskette 

The diskette storage medium is a magnetically coated disk 
that is permanently enclosed in a jacket. Small slots in the 
jacket allow the read/write heads to contact the surfaces 
as the disk rotates within the jacket. The disk and jacket, 
together, are referred to as a diskette. See Figure 2-3. 


Temporary Adhesive Identification Label 






This label can be used to describe data stored on the 
diskette or to record other temporary information about 
the diskette. 


Permanent Diskette Label 
This label is permanently affixed to the diskette. It can 
be used to record permanent information, such as the 


diskette identification number, for a quick visual identi- 
fication of the diskette. 


347-73 





Diskette No. Payroll Detail 347-73 





Payroll Detail 


IBM 
Diskette 1 





8 in. Location of index | ~ Index Hole 

(20cm) hole in The outer circle shows a hole in the jacket; the inner 
two-sided diskettes circle shows the index hole in the diskette. When these 

two holes are aligned as the disk revolves during data 

processing operations, a beam of light shining on one 

side of the diskette is sensed from the other side and 

used for timing functions. 


Drive Access Opening in Jacket 


Drive Spindle Hole in Disk 


After the diskette has been placed in the machine and 
the diskette drive spindle has been inserted into the 
drive spindle hole in the disk, the drive mechanism 
clamps onto a portion of the disk exposed by the drive 
access opening in the jacket. 


Stress Relief Notches 
The stress relief notches in the diskette jacket aid in 
Head slot distributing the stress in the slot area if the diskette 
is bent. 


The head slot exposes the recording surface of the disk 
as the disk turns in its jacket in the machine. The data 
recording and sensing unit of the diskette unit, which 
is called a read/write head and is similar to the record/ 
playback head in a tape recorder, moves to specified 
positions along the length of the slot. Moving to a 
specified position is called accessing a track. 


Figure 2-3. Diskette storage medium 
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Diskette Surface Format 


Depending on the type of diskette (IBM Diskette 1 or 
Diskette 2), one or both sides are formatted with tracks 
divided into sectors. The Diskette 1 contains 74 data tracks 
on the head 0 side of the diskette. The head 1 side of the 
Diskette 1 is blank and cannot be used. The Diskette 2 
contains 74 data tracks on both sides of the diskette. The 
number of sectors on each track—26, 15, or 8—depends on 
the sector length—128, 256, or 512 bytes respectively. 


Cylinders 

On a Diskette 1, the terms cylinder and track are 
synonomous. On a Diskette 2, a cylinder consists of the 
pair of tracks (one on each side) that can be read or 
written without moving the heads. 


Index 


When the index hole in the diskette passes a light source, 
an index timing pulse is generated. The index timing pulse 
signals the beginning of a track and occurs each time the 
diskette rotates. The index timing pulse is used to begin 
Format Track operations and to determine whether a 
Diskette 1 or Diskette 2 is installed in the diskette unit. 
See Figure 2-4. 

An attempt to access the head 1 side of a Diskette 1 
ends the operation and sets the DCB specification check in 
the interrupt status byte to 1. Refer to “Interrupt Status 
Byte” in Chapter 4. 


WW 
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26 Sectors 
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15 Sectors 


Tracks 


Diskette surfaces are divided into 77 tracks with each 

track divided into fixed-length sectors. A sector is a 
physical location on the diskette; sector format is described 
in the following section. A sector can hold all or part of a 
record. If the record is shorter than the sector length, 
unused bytes are padded with binary zeros. If a record is 
longer than the sector length, the record is written over as 


" many sectors as its length requires. 


The data storage capacity of a track depends on track 
format. Tracks can be formatted with one of three fixed- 
length sector sizes: 


Sector Size Track Storage 
Capacity Sectors per Track Capacity 

128 bytes ' 26 3328 bytes 
256 bytes 15 3840 bytes 
512 bytes 8 4096 bytes 


The ability to choose a sector size is especially useful 
if records length requirements change from job to job and 
thus from diskette to diskette. The sector size that pro- 
vides the most efficient use of diskette space can be chosen 
depending on the record length required. 

Tracks must be numbered from 00 (outermost) to 76 
(innermost). The tracks should be used in the following 
ways: 


@ Reserve track 00 for system use as a label track. 
e@ Reserve track 01 through 74 for data; until used for 
data they contain unallocated free space. 


_@ Reserve tracks 75 and 76 for use as alternates. 


8 Sectors 
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Each sector consists of a sector identifier (sector ID) and 
a data field. The sector ID holds the unique address for 
the sector. Refer to the following section, “Sector ID 


Sector numbers are assigned beginning with 01 for the 
first sector after index. There are 26 sectors if the sector 
length for the diskette is 128 bytes, 15 sectors if the 
length is 256 bytes, and 8 sectors if the length is 512 bytes. 





oa ‘ ~ as 
{fas Secor] [Secor 01 [Sexo [Sato 
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_ ID Fidld Data Field ~~. 


Sync ae Sync 
{Shoals boomers] ow [a 
‘a i a AM2: hex FB or F8 2 o ct 


FB = data field 

F8 = control field 

(The control field should 
: begin with a D or an F: 
Record | Physical D = deleted record 


Number patie F = defective record) Six bytes of zeros. 






Number {| Number 





| 2 Cyclic redundancy check. 
The check bytes are 
generated during a write 
operation. They are used 
during a read operation 
to verify that data is 

Hex 01 through 1A for 128 byte per sector format diskette read correctly. 

Hex 01 through OF for 256 byte per sector format diskette 3 

Hex 01 through 08 for 512 byte per sector format diskette Ei Rost-ID gap. 


4 | Post-data gap. 


Hex 00 for 128 byte per sector format 
Hex 01 for 256 byte per sector format 
Hex 02 for 512 byte per sector format 


Hex 00 for one-sided diskettes and side 0 of two-sided diskettes 
Hex 01 for side 1 of two-sided diskettes 


Hex 00 through 4A (Decimal 0 through 74. Cylinders 75 and 76 


Hex FE (identifies ID field) are used as alternate cylinders.) 


Figure 24. Diskette track format 
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Sector ID Format 


The sector ID consists of seven bytes, and each sector on 
the diskette has a unique ID. The sector ID has the follow- 
ing format: 


ID 
AMI | C H R N CRC CRC 
Byte Byte Byte Byte Byte Byte Byte 


AM1. This Address Marker (AM) signals the start of each 
sector. The AMI byte is always X‘FE’. 


C-Byte. The C-byte contains a binary number that desig- 
nates the cylinder in which the sector is located (cylinders 
00 through 76). The C-byte corresponds to the cylinder 

address byte in the Device Control Block (DCB). Refer to 
“Using the DCB” in Chapter 4. 


H-Byte. The H-byte identifies the head used to access the 
sector. Because the diskette unit contains two heads, 0 and 
1, this byte must contain a value of either X‘00’ or X‘01’. 
Otherwise, the response to all data transfer operations 
except Read Sector ID is ‘no record found’. The H-byte 
corresponds to the head selection byte in the Device 
Control Block (DCB). Refer to “Using the DCB” in 
Chapter 4. 


R-Byte. The R-byte identifies the sector number. The 
sector number must be specified with a binary number that 
represents 01 through 26 for 128-byte sectors, 01 through 
15 for 256-byte sectors, or 01 through 08 for 512-byte 
sectors. The R-byte in the sector ID corresponds to the 
sector number byte in the Device Control Block (DCB). 
Refer to “Using the DCB” in Chapter 4 and the note after 
“CRC Bytes” in this chapter. 
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N-Byte. The N-byte designates the byte length of each 
sector on the track. The N-byte must contain hexadecimal: 


© 00 for tracks formatted with 128-byte sectors 
© 01 for tracks formatted with 256-byte sectors 
@ 02 for tracks formatted with 512-byte sectors 


Using any other N-byte designation causes a DCB 
specification check for all data transfer operations except 
Read Sector ID. The N-byte corresponds to the sector. 
length byte in the Device Control Block (DCB). Refer to 
“Using the DCB” in Chapter 4 and the note after “CRC 
Bytes”’ in this chapter. 


CRC Bytes. A two-byte Cyclic Redundancy Check (CRC) 


field is calculated as each sector ID is written. The CRC 
bytes are written immediately after the sector ID bytes. 
They are also calculated and written after the data field in 
each sector. The CRC bytes are recalculated each time 
information is read from the diskette and compared with 
previously written CRC bytes. An unequal comparison sets 
error indications. 

The cyclic redundancy check provides the following 
error detection capability: 


© 100% of odd bit errors 
@ 100% of single burst failures of 16 bits or less 


-@ 99.9985% of random errors 


Note. During all data transfer operations except Read 
Sector ID, the C-byte, H-byte, R-byte, and.N-byte of the 
sector ID are specified as a search argument in the DCB. 
The required sector is located by comparing sector IDs on 
the diskette with the search argument in the DCB. When 
an equal comparison occurs, the data transfer begins. 


This chapter describes the I/O commands required to 
perform input/output operations on the IBM 4962 Disk 
Storage Unit. The commands that can be issued, the in- 
struction and control blocks required for each command, 
and the individual disk operations are described. Status 
information and I/O interrupts are also described in this 
chapter. 


Data Transfer Operations 


Data is transferred on the I/O channel in a parallel opera- 
tion (16 data bits plus 2 parity bits). On a write operation, 
parity bits are removed and the data bits are transferred 
serially to the disk. On a read operation, the data bits are 
read serially from the disk, parity bits are added, and the 
information is transferred one word at a time into processor 
storage. The direction in which data moves on the channel 
is determined by the I/O command. The command also 
determines whether data is transferred to or from processor 
storage under direct program control only, or under direct 
program control and in cycle steal mode. 


Direct Program Control (DPC) 


An I/O command executed under direct program control 
transfers a word of data or control information into or from 
processor storage. After moving the immediate data, the 
processor continues with other instructions. 


Cycle Steal (CS) Mode 


When data is transferred in cycle steal mode, processing 

and I/O operations are overlapped. Overlapping allows the 
processor to execute other instructions while the disk unit 
is cycle stealing the data required to complete an I/O opera- 
tion. Data is moved to or from processor storage by stealing 
cycles from the processor. 


Initiating a Disk Operation 

Every I/O operation to the disk unit requires (in processor 
storage): 

1. an Operate I/O instruction 


2. anI/O command, device address, and an immediate 
data field. 
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Operate I/O Instruction 


The Operate I/O instruction points to an Immediate Device 
Control Block (IDCB) in storage containing an I/O com- 
mand, device address, and immediate data field. Refer to 
the following section for more detail. Every Operate I/O 
instruction must have an associated IDCB. 


Note. The Operate I/O instruction is described more com- 
pletely in IBM Series/1 processor unit description manuals. 
Refer to the Preface of this manual for titles and order 
numbers. 


The format of the Operate I/O instruction is: 


R2 Function 
1100 
8 


Operate I/O instruction 


Operation code 
01101 
0 





4 5 7 10 11 12 15 
16 31 
Using the IDCB 


An Immediate Device Control Block (IDCB) must be re- 
served in processor storage for every I/O command issued 
to the disk unit. Before issuing an Operate I/O instruction 
to the disk unit, an I/O command must be stored in the 
command field of the associated IDCB. The immediate 
data field of the IDCB must contain a data word, a DCB 
address or zeros. I/O commands that execute only under 
direct program control require a data word or zeros, while 
commands that also transfer data in cycle steal mode re- 
quire a DCB address. Refer to the following section. 

The format of the IDCB is: 


IDCB Gimmediate device control block) 


Command field Device address field 
X X X X X X X X{O X K X X X X X 


0 7 8 15 


00-—FF 


Immediate data field 


DCB address/immediate data word/zeros 


16 31 
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I/O Commands and Disk Operations | 
The I/O command, stored in the IDCB, determines whether 
a single word of immediate data is transferred under direct 
program control only or, following the DPC operation, 
additional words of data are to be transferred into or from 
processor storage in cycle steal mode. See Figure 3-1. 


Series/1 
instruction 
process 


Operate I/O All I/O commands 


(data word, zeros, or DCB address) 





IDCB 
DPC , 
operation IDCB Device ID (Read Device ID only) 
Condition code response to Operate I/O 
Only I/O commands that interrupt 
DCB Cycle steal DCB 
Cycle 
steal 
operations 


Cycle steal data 





Interrupt request 


Interrupt service 





Transfer condition code and Interrupt ID word 


Figure 3-1. Overview of an I/O operation 
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1/O 
device 


Command Execution Under Direct 
Program Control 


Prepare, Device Reset, and Read Device ID commands trans- 
fera single word of data to or from the immediate data field 
of an IDCB in storage. Command execution is complete 
when a condition code is reported to the processor follow- 
ing the DPC operation. Refer to “Condition Codes” later in 
this chapter. Processing of other instructions resumes when 
the I/O operation ends. See Figure 3-2. 


Operate I/O instruction 


Operation code R2 Function Address 
011041 1 10 0 
0 4 5 7 8 


101112 15 16 
yo 


31 


al 






Effective address 


IDCB (immediate device control block) 


Command fied Device address fet 
KXXXXxxXX_XxxxXXXxXf Dates 


0 7 8 15 16 





LSR 


lel] G2 


ae . ‘ 
Condition code response to DPC operation 


LSR Bit 0 even indicator 
Bit 1 carry indicator 
Bit 2 overflow indicator 


Sn Ee, cS 


Data transfer under DPC 





31 








I/O device 







Figure 3-2. I/O operation initiated and executed exclusively under direct program control 


Prepare Command 


Before using any of the interrupt-causing commands, a 
Prepare command must be issued to the disk unit. The 
Prepare command transfers a word containing interrupt 
parameters from the IDCB immediate data field associated 

with the command to the Prepare Register in the disk 
attachment. The interrupt parameters in this word establish 
whether the disk unit is allowed to interrupt, and if so, the 
level on which processing operations can be interrupted. 
The Prepare command is executed under direct program 
control and does not cause an interrupt. 


IDCB (immediate device control block) 


Command field Device address field 
0110000 0X X X X X XK XK X 
0 7 8 15 
=, a ee, 


60 00—FF 


Immediate data field 


16 26 27 © 30 


0 = interrupts disabled | 


1 = enable interrupts 


1 


uy 


Note. Refer to “Prerequisite Publications” in the Preface of this 
manual. Processor description manuals contain information 
about interrupt levels. 
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Device Reset Command 


The Device Reset command resets all pending interrupts 
and previously established control and status conditions. 
The device ID, device address, data address, residual address, 
and prepare registers are not reset by this command. The 
command code and device address in the IDCB supply the 
information required to execute the Device Reset command. 
Although the IDCB immediate data field is not used and not 
checked, set the bits to zero. The Device Reset command is 
executed under direct program control and does not cause 
an interrupt. 

The format of the IDCB for a Device Reset command is: 


IDCB Gmmediate device control block) 


Command field Device address field 
0 110i1%1i1é%3K KX X X XO XOX OX 


0 7 8 15 
a ~eeen,_ poe 


OF 00-FF 


0000000000000000 


16 31 


Read Device ID Command 

The Read Device ID command loads the disk unit device ID 
word into the immediate data field of the IDCB associated 
with the command. Read Device ID executes under direct 
program control: the device ID is transferred immediately 
into storage, and a condition code is reported to the proc- 
essor. Refer to “Status Information” later in this chapter. 


The Read Device ID command does not cause an interrupt. 
The format of the IDCB for the Read Device ID com- 
mand is: 


IDCB (immediate device control block) 


Command field Device address field 
0010000 0[X X X XK X X X X 


0 7 8 15 
Sue, moe” Se, 
20 00-—FF 


immediate data field | 
000000000000000 0 


16 31 
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During command execution, the device ID is transferred 
under DPC to this field. After execution of the Read Device 
ID command, the immediate data field in the IDCB associa- 
ted with the command contains: 


Model dependent 
31 


16 
nn mmm 


00AA = without fixed heads (Models I and 2) 
OOBA = with fixed heads (Models IF and 2F) 
00CA = with three movable heads (Models 3 and 4) 


Command Execution in CS Mode 


Start and Start Cycle Steal Status commands transfer data 
in cycle steal mode. The DCB address associated with either 
command, however, is transferred under DPC from the 
IDCB immediate data field in processor storage to the disk 
unit. See Figure 3-2. When the disk unit accepts the com- 
mand and DCB address, a condition code is reported to the 
processor. The processor continues with other operations 
and the disk unit begins cycle stealing the data required to 
complete the I/O operation. When the transfer of data in 
cycle steal mode ends, an interrupt request is sent to the 
processor. At interrupt presentation time a condition code 
and interrupt ID word are transferred to the processor. The 
I/O operation ends and the processor continues with other 
operations. 

The immediate data field of an IDCB containing either 
a Start or Start Cycle Steal Status command must point to 
a Device Control Block (DCB). See Figure 3-3. The DCB 
must contain the control information and device parameters 
required to execute an I/O operation in cycle steal mode. 
Refer to the following section. 


\ 
Operate J/O instruction 


Operation code R2 Function Address 
011041 1 10 0 
0 4 5 7 8 

a etl 


101112 15 16 31 
a, 












Effective address 


IDCB (immediate device control block) 

Command field Device address field 
X X X X X X X KIX X K K K X X X DCB address 0500 

0 


7 





8 15 16 31 
a ceeeeseecemmenetinimmeemeneatemeeeesmeree  meceeaetne ele 


Data transfer under DPC 


1/O device 


LSR 


Eco] OY 
— 
Condition code response to DPC operation 


LSR Bit 0 even indicator 
Bit 1 carry indicator 
Bit 2 overflow indicator 


Address DCB 


0500 


Cycle steal DCB words 
DCB data 


a 


(8 words) 





I/O device 


Address data area 


0800 


Cycle steal data 
Data area 


Interrupt ID word 


LSR 
Priority interrupt 
E} cf ol4 condition code 
N 0 7 8 15 and interrupt ID 
SS, 2 


word 


Figure 3-3. I/O operation initiated under direct program control and executed in cycle steal mode 


Programming Disk Operations 


Page of GA34-0024-1 
As updated August 17, 1979 
By TNL GN34-0550 


Using the DCB 


A Device Control Block (DCB), comprised of eight contig- 
uous words in processor storage, must be reserved for every 
I/O operation that moves data in cycle steal mode. See 
Figure 3-4. A separate DCB is required for: 


@ a Start command 

@ aStart Cycle Steal Status command 

@ all disk operations included in a DCB command chaining 
sequence (refer to “DCB Command Chaining” later in 
this chapter.) | 


Device parameters that define and control the I/O opera- _ 


tion must be stored in each DCB. 


DCB address 
(hexadecimal) Control word 


DCB (device control block) 


(+2) Seek control word 


Physical 
fe. 
4) sector count 


(+6) Cylinder address 


(+8) Head selection 


Sector number 


(tA) Chain address 
(+C) Byte count 


(+E) Data address 





0 15 


Figure 3-4. DCB format (Start command shown) 


General information about each word and field in the 
DCB is supplied in the sections that follow; specific infor- 
mation appears in the description for each operation later 
in this chapter. . 


DCB Control Word (DCB Word 0) 


Figure 3-5 shows the format of the DCB control word. This® 
word occupies the first position of each DCB associated 
with a Start or Start Cycle Steal Status command. The DCB 
control word delineates the disk operation. 


DCB control word 


Prot key | Modifier bits - 
X X XJ Device dependent 
5 


6 7 8 15 


ma 
ro) 


xX 0 0 
23 4 


S 
hme 


Reserved . 
Reserved 
Input flag 
Reserved 
Chaining flag 


Ii 


Figure 3-5. DCB control word format 
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The meaning of the bits is as follows: 
Bit 0 Set this bit to 1 to specify DCB command | 


(chaining flag) chaining. When the operation called for by the 
current DCB ends, the chain address stored in 
DCB word 5 points to the next DCB in the 
chained sequence. Refer to ‘(DCB Command 
Chaining” later in this chapter. — 

Bit 1 Set this bit to 0 to avoid future code 

(reserved) obsolescence. 

Bit 2 Set the input flag bit to 1 for disk operations 
(input flag) ' that transfer data into processor storage. Set the 
bit to 0 for disk operations that transfer data 

from storage and for Seek/Seek Recalibrate 
operations. 
Note. If the input flag bit setting is not consis- 
tent with the type of operation: the operation 
ends and an interrupt request is sent to the 
processor. At interrupt presentation time, an 
exception condition and a DCB specification 
check are presented to the processor. 

Bit 3 Set this bit to 0 to avoid future code 

(reserved) obsolescence. , 

Bit 4 Set this bit to 0 to avoid future cod 

(reserved) obsolescence. 

Bits 5—7 - These bits represent the cycle steal address key 

(address key) required for storage authorization at cycle steal 
request time. . a . 

Bits 8—15 The bits in this field are device dependent 


modifiers of the Start command. A bit con- 
figuration must be selected that represents the 
disk operation to be performed. The selected 
disk operation must be compatible with the 
setting of the input flag bit (bit 2). The hexa- 
decimal designation for each disk operation and 
the corresponding setting of bit 2 are shown in 
Figure 3-6. 

- Note. Burst mode (bit 15) is not supported by 
the 4962 and 4964. 


DCB control word Hexadecimal 


Bit2 modifier bits 8-15 equivalent Operation 

0 00000001 01 Write Data 

0 00000010 02 Write Sector ID 

0 00000011 03 Write Sector ID Skewed 
1 00001001 09 Read Data 

1 00001100 0c Read Verify 

1 00001010 OA Read Sector ID 

1 00001011 OB Read Sector ID Skewed 
1 00001000 08 Read Diagnostic 

0 00000101 05 Seek 

0 00000111 07 Seek Recalibrate 


Figure 3-6. DCB control word modifier bit configurations 


~ Seek Control Word (DCB Word 1) 


The seek control word is used, in conjunction with the head 
address specified in the high-order byte of DCB word 4, to 
control Seek operations. The seek control word specifies 
the direction of the seek—either toward the outer perimeter 
of the disk or toward its center—and the number of cylin- 
ders to be crossed. Figure 3-7 shows the format of the seek 
control word. 


Notes. 


1. Use the seek control word only for Seek operations. 

2. Ifthe seek control word is set to zero, no seek move- 
ment occurs. 

3. Because they are not required for a Seek operation, set 
DCB word 3, DCB word 6, and the sector number in 
DCB word 4 to zero. The search argument and byte 
count are not used in Seek operations. 


Seek control word 


0000xX00 XxX XK XK XK XX XX 





0 3 45 67 15 
—_——’ —— 
| = Seek difference 
Reserved 
Seek direction 
Reserved 


Figure 3-7. Seek control word format 


The meaning of the seek direction and seek difference 
fields are as follows: 


Bit 4 To increase the cylinder number (seek toward 
(seek direction) the outer edge of the disk), set this bit to 0. To 
seek to a lower cylinder number (toward the 
center of the disk), set this bit to 1. 
These nine bits specify the seek difference (the 
number of cylinders to be moved). If a seek dif- 
ference of zero is specified, no movement occurs 
and a device end condition code is transferred 
to the processor at interrupt presentation time. 
Bits O—3 and 5—6 in the seek control word are reserved and must 
be set to zeros to avoid future code obsolescence. 


Bits 7—15 
(seek difference) 


Physical Sector Count and Flag (DCB Word 2) 


DCB word 2 is comprised of two one-byte fields: the physi- 
cal sector count and the flag byte of the search argument. 


Physical Sector Count 


This byte is required only for the sector-counting disk 
operations: Write Sector ID, Write Sector ID Skewed, Read 
Sector ID, Read Sector ID Skewed, and Read Diagnostic. 
These disk operations are used to locate a specific sector on 
the disk without reading sector ID bytes. Factory written 
sector bytes are recorded at the beginning of every sector 
location on the disk. The sector counting operations locate 
a specific sector on a track, by counting these sector bytes. 
A physical sector byte count that is one less than the desired 
physical sector location must be stored in the DCB associa- 
ted with each sector-counting disk operation. For example: 


Desired physical Physical 
sector location byte count 
00 59 

Ol 00 

02 01 

03 02 
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Flag 


A search argument comprised of the flag byte, the cylinder 
address in DCB word 3, and the head and sector addresses 
in DCB word 4 is used to locate the first sector in a Read 
Data, Write Data, or Read Verify operation. Sector IDs are 
read from the disk track, and compared to the search argu- 
ment. When an equal comparison occurs, the transfer of 
data begins. The flag byte is the first byte of the sector ID; 
bits 6 and 7 specify the disk surface condition for the sector. 
Bits O—5 are reserved and must be set to zero to avoid future 
code obsolescence. Bits 6 and 7 have the following meanings: 


Bits 6-7 Disk surface condition indicator 


00 good primary sector 

10 defective primary sector 

01 good alternate sector 

11 defective alternate sector (cylinder 001) 


Cylinder Address (DCB Word 3) 

The cylinder address of the required sector must be specified 
in DCB word 3. The cylinder address is the second and third 
bytes in the sector ID. A right adjusted binary number from 
000 to 302 must be specified to identify the cylinder con- 
taining the data to be accessed. The cylinder address is part 
of the search argument used to locate the first sector in- 
volved in a Read Data, Write Data, or Read Verify operation. 


Notes. 


1. Bits O—6 of the cylinder address must always be set to 
Zeros. 

2. Acylinder address of 152 should be specified in the 
DCB search argument for Write Sector ID and Write 
Sector ID Skewed operations on the fixed R/W heads. 


Head Selection and Sector Number (DCB Word 4) 


DCB word 4 consists of two one-byte fields: head selection 
and sector number. 


Head Selection 


Head selection can only be accomplished with the Seek 
operation. To change head selection without changing 
cylinders, perform a Seek operation with the desired head 
designation in the head selection byte and a seek difference 
of zero in the seek control word (DCB word 1). The possible 
bit configurations (and their hexadecimal equivalents) for 
the head selection byte are: 


Head selection byte | Hexadecimal 
bit configurations equivalents 
Select movable head: 0 0000 0000 00 
1 0000 0001 01 
2 0000 0010 02 
Select fixed head: 0 1000 0000 80 
1 1000 0001 81 
2 1000 0010 82 
3 1000 0011 83 
4 1000 0100 84 
ms) 1000 0101 85 
6 1000 0110 86 
7 1000 0111 87 
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Head Selection and Sector Number (DCB Word 4) 


DCB word 4 consists of two one-byte fields: head selection 
and sector number. 


Head Selection 


Head selection can only be accomplished with the Seek 
operation. To change head selection without changing 
cylinders, perform a Seek operation with the desired head 
designation in the head selection byte and a seek difference 
of zero in the seek control word (DCB word 1). The possible 
bit configurations (and their hexadecimal equivalents) for 
the head selection byte are: 


Head selection byte Hexadecimal 
bit configurations equivalents 
Select movable head: 0 ° 0000 0000 * 00 
1 0000 0001 01 
2 0000 0010 © ' 02 
Select fixed head: 0.- 1000 0000 80 
1 1000 0001 81 
2 1000 0010 82 
3 1000 0011 83 
4 1000 0100 84 
5 1000 0101 85 
6 1000 0110 86 
7 1000 0111 87 


Sector Number 


The low-order byte of DCB word 4 specifies the sector 
number. A right-adjusted binary number from 00 to 59 
must be used to specify the sector to be accessed. 


Chain Address (DCB Word 5) 


To chain disk operations, set the chaining flag bit in the 
DCB control word (DCB word 0) to 1. The address of the 
next DCB in the chain must be specified in the chain address 
(DCB word 5). The address must be an even number. If the 
chained-to address is an odd number (bit 15 is-on), no data 
is transferred, and a DCB specification check is set in the 
interrupt status byte and transferred to the processor at 
interrupt presentation time. 


Byte Count (DCB Word 6) 

The byte count specifies the number of bytes to be trans- 
ferred between processor storage and the disk unit. The 
byte count must be an even number and cannot be zero. If 


bit 15 is set on (indicating an odd byte count) or-the count ° 


is zero: the operation ends, no data transfer takes place, 
and a DCB specification check is presented to the processor. 

Several I/O operations to the disk unit require a specific 
hexadecimal value in the byte count: 


1. The byte count for a Start Cycle Steal Status command 
must contain X‘0008’. 
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2. For disk operations initiated with a Start command, 
the following hexadecimal values must be stored in the 


byte count: 

Disk operation _ Byte count (in hex) 
Read Sector ID 0006 

Read Sector ID Skewed 0006 

Write Sector ID’ ‘0006 

Write Sector ID Skewed 0006 

Read Diagnostic 0100 


3. For Read Data, Write Data, and Read Verify operations, 
the byte count depends on the program requirements. 
For these operations, the byte count has the following 


format: 
No, of full sectors No. of bytes in partial sect. 


0 7 8 15 


Bits O—7 specify the number of full sectors to be trans- 
ferred. For example: if a record is exactly 512 bytes long 
(two sectors), store X‘02’ in bits O—7 of the byte count. 

Bits 8—15 are used if the record is less than a full sector, 
or if the last sector in a multi-sector transfer contains less 
than 256 bytes of data. Use a hexadecimal value to specify 
the number of bytes in a partially filled sector. 


Example: . 
To transfer an 80-byte record, specify (in hexadecimal) 
00 SO 
| tt number of bytes in partial sector 
number of full sectors 
To transfer a 256-byte record, specify (in hexadecimal) 
01 00 - 
| ca number of bytes in partial sector 
number of full sectors | 
To transfer a 600-byte record, specify (in hexadecimal) 
02 58 


| a number of bytes in partial sector 

number of full sectors 
Note. On write operations involving a sector that is only © 
partially filled with data, the disk unit writes the data called 
for in the DCB and then pads the balance of the sector with 
binary zeros. When the record is subsequently read, the — 
padded zeros are included in the data field CRC verification. 


Only the number of data bytes specified in the DCB byte 
count, however, are transferred into storage. 
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Data Address (DCB Word 7) 


This DCB word contains the beginning address of the proc- 
essor Storage location used in the data transfer. During a 
read operation, the first word read from the disk is stored 
into this location; data is transferred into succeeding storage 
locations until the byte count has been fulfilled. During a 
write operation, the word stored at this location is written 
to the first word in the sector specified; words are written 
in succeeding locations on the disk until the byte count has 
been fulfilled. 

The data address stored in this word must identify a 
storage location on an even address boundary. If the data 
address is odd (bit 15 is set to one), the operation ends and 
an interrupt request is sent to the processor. At interrupt 
presentation time, a DCB specification check is transferred 
to the processor. Refer to “I/O Interrupts” later in this 
chapter. 


DCB Command Chaining 


Obtaining a new DCB upon completion of the operation 
specified in the current DCB without issuing a new Operate 
I/O instruction is called DCB command chaining. The DCBs 
belonging to such a sequence are said to be chained. 
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Sector Number 


The low-order byte of DCB word 4 specifies the sector 
number. A right-adjusted binary number from 00 to 59 
must be used to specify the sector to be accessed. 


Chain Address (DCB Word 5) 


To chain disk operations, set the chaining flag bit in the 
DCB control word (DCB word 0) to 1. The address of the 
next DCB in the chain must be specified in the chain address 
(DCB word 5). The address must be an even number. If the 
chained-to address is an odd number (bit 15 is on), no data 
is transferred, and a DCB specification check is set in the 
interrupt status byte and transferred to the processor at 
interrupt presentation time. 


Byte Count (DCB Word 6) 


The byte count specifies the number of bytes to be trans- 
ferred between processor storage and the disk unit. The 
byte count must be an even number and cannot be zero. If 
bit 15 is set on (indicating an odd byte count) or the count 
is zero: the operation ends, no data transfer takes place, 
and a DCB specification check is presented to the processor. 

Several I/O operations to the disk unit require a specific 
hexadecimal value in the byte count: 


1. The byte count for a Start Cycle Steal Status command 
must contain X‘0008’. 

2. For disk operations initiated with a Start command, 
the following hexadecimal values must be stored in the 


byte count: 

Disk operation Byte count (in hex) 
Read Sector ID 0006 

Read Sector ID Skewed 0006 

Write Sector ID 0006 

Write Sector ID Skewed 0006 

Read Diagnostic 0100 


3. For Read Data, Write Data, and Read Verify operations, 
the byte count depends on the program requirements. 
For these operations, the byte count has the following 


format: 
No. of full sectors No, of bytes in partial sect. 
0 7 8 15 


Bits O—7 specify the number of full sectors to be trans- 
ferred. For example: if a record is exactly 512 bytes long 
(two sectors), store X‘02’ in bits O—7 of the byte count. 

Bits 8—15 are used if the record is less than a full sector, 
or if the last sector in a multi-sector transfer contains less 
than 256 bytes of data. Use a hexadecimal value to specify 
the number of bytes in a partially filled sector. 
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Example: 
To transfer an 80-byte record, specify (in hexadecimal) 


00 50 
| “Es number of bytes in partial sector 
number of full sectors 
To transfer a 256-byte record, specify (in hexadecimal) 
01 00 
| TL number of bytes in partial sector 
number of full sectors 
To transfer a 600-byte record, specify (in hexadecimal) 
02 58 


gas number of bytes in partial sector 
number of full sectors 


Note. On write operations involving a sector that is only 
partially filled with data, the disk unit writes the data called 
for in the DCB and then pads the balance of the sector with 
binary zeros. When the record is subsequently read, the 
padded zeros are included in the data field CRC verification. 
Only the number of data bytes specified in the DCB byte 
count, however, are transferred into storage. 


Data Address (DCB Word 7) 


This DCB word contains the beginning address of the proc- 
essor storage location used in the data transfer. During a 
read operation, the first word read from the disk is stored 
into this location; data is transferred into succeeding storage 
locations until the byte count has been fulfilled. During a 
write operation, the word stored at this location is written 
to the first word in the sector specified; words are written 
in succeeding locations on the disk until the byte count has 
been fulfilled. 

The data address stored in this word must identify a 
storage location on an even address boundary. If the data 
address is odd (bit 15 is set to one), the operation ends and 
an interrupt request is sent to the processor. At interrupt 
presentation time, a DCB specification check is transferred 
to the processor. Refer to “I/O Interrupts” later in this 
chapter. 


DCB Command Chaining 


Obtaining a new DCB upon completion of the operation 
specified in the current DCB without issuing a new Operate 
I/O instruction is called DCB command chaining. The DCBs 
belonging to such a sequence are said to be chained. 


When DCBs are chained, the first DCB in the chain con- 
tains the address of the next DCB. As each operation in a 
chained sequence is completed, the chain address stored in 
the current DCB is used to cycle steal the next DCB in the 
chain. The chained-to DCB is examined to determine which 
operation is next in the sequence and whether the associated 
device parameters are valid. DCB command chaining opera- 
tions continue until a DCB is fetched that has the chaining 
bit in the control word (DCB word 0) set to 0, indicating 
the last operation in the chain. If an error occurs, chaining 
to succeeding DCBs is automatically suspended, and an 
interrupt request is sent to the processor. Normally, an 
interrupt is not requested until the disk unit has completed 
the last operation in the chain. 

DCB command chaining reduces the processing time 
required to execute I/O operations to the disk unit. For 
example: a single Operate I/O instruction can: 


@ Seek toa new cylinder location and change head selection 
@ write a record 

@ verify that the record was written properly 

@ seek to a newcylinder location and change head selection 
@ read a record, etc. 


Start Command 


Start commands initiate I/O disk operations that transfer 
data into or from processor storage in cycle steal mode. 
An interrupt request is sent to the processor when the I/O 
operation ends. An Operate I/O instruction must point to 
an IDCB containing each Start command, and the IDCB 
immediate-field must contain the address of a DCB. The 
control information and parameters required for a partic- 
ular disk operation must be stored in the DCB associated 
with that operation. Refer to “Using the DCB” earlier in 

- this chapter. The disk operations initiated with a Start 
command are: 


Seek 

Seek Recalibrate 

Read Data 

Write Data 

Read Verify 

Write Sector ID 

Read Sector ID 

Write Sector ID skewed 
Read Sector ID skewed 
Read Diagnostic 


Note. Refer to the description of each individual disk 
operation in this chapter for the format of each DCB con- 
trol word and the programming considerations applicable 
to each operation. 


When the Operate I/O instruction is issued, the Start 
command is transferred under direct program control from 
the IDCB to the attachment where it is checked for errors 
and validity. If the command is accepted, a ‘satisfactory’ 


condition code (CC=7) is sent to the processor. While the 
disk unit is ‘busy’ executing the I/O operations, the proces- 
sor continues with other operations. Beginning at the DCB 
address specified in the IDCB, the eight words in the DCB 
are transferred to the disk unit from processor storage. The 
data is transferred in cycle steal mode one word at.a time. 
The DCB information is decoded and the disk unit begins 
executing the operation called for in DCB control word 
(DCB word 0). When the operation (or operations when 
chaining) ends, an interrupt request is sent to the processor. 
At interrupt presentation time, a condition code and an in- 
terrupt ID word containing status information are presented 
to the processor. . 
The format of the IDCB for a Start command is: 


IDCB (immediate device control block) 


Command field Device address field 
014131000 0/;/XK X X X XO XK XK OX 


0 7 8 15 
Se, oe “a 


70 O00-—FF 


Immediate data field 


DCB address 
16 31 


The format of the DCB for a Start command is: 


DCB (device control block) 










DCB address Wore 
(+E) 7 





Data address 
0 15 


Control word format (DCB word 0) 


Addr key] Modifier bits 
a 


0123 45 7 8 


— 


Reserved 
Reserved 
Input flag 
Reserved 
Chaining flag 
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Programming Considerations 


1. Every disk operation initiated with a Start command 
that requires a change in either head selection or cyl- 
inder location must be preceded by a Seek operation. 

2. When DCB command chaining is used to perform a 
series of disk operations, an interrupt is not requested 
until either an error occurs or the last operation in the 
chained sequence is complete. 

3. To specify DCB chaining: 

a. For every operation in a DCB command-chained- 
sequence, except the last, set the chaining flag in 
each DCB control word (DCB word 0) to 1. 

b. Set the address of the chained-to DCB in the chain 
address (DCB word 5). 

4. Forevery I/O operation initiated with a Start command 
that is not included in a DCB command-chained- 
sequence, store (in processor storage): 

a. an Operate I/O instruction that points to an IDCB 

b. a Start command with a device address and a DC 
address in an IDCB : 

c. a DCB that contains device parameters and control 
information defining a particular disk operation 

5. The disk unit responds ‘busy’ to all commands except 
Prepare, Device Reset, Read ID, or Halt I/O from the 
time the Start command is received until an interrupt 
request is serviced by the processor. 

6. Acylinder address of 152 should be specified when a 
fixed head is accessed by a Write Sector ID or Write 
Sector ID Skewed operation. The movable heads must 
be positioned over cylinder 152 for every Write Sector 
ID or Write Sector ID Skewed operation performed on 
the fixed heads. The position of the movable heads is 
of no importance for all other fixed head operations. 


Seek Operation 


A seek must precede every I/O operation to the disk unit 
requiring a move of the heads to another cylinder or a 
change in head selection. The Seek operation can be used 
to change: head selection, only; cylinder location, only; 
or both head selection and cylinder location. The DCB 
associated with a Seek operation is transferred to or from 
processor storage in cycle steal mode. An interrupt request 
is sent to the processor when the disk unit completes the 
operation. A condition code and interrupt ID word are 
transferred to the processor when the interrupt is serviced. 
Refer to “I/O Interrupts” and “Condition Codes” later in 
this chapter. 

The control information and parameters required for a 
Seek operation must be stored in a DCB. The DCB must 
contain: 


@ a DCB control word defining a Seek operation to the 
disk unit (DCB word 0). 

@ aseek control word specifying the seek direction and 
number of cylinders to be crossed (DCB word 1). 
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@ ahead select byte that specifies which head is to be used 
(high-order byte of DCB word 4). 

® achain address if DCB command chaining is specified in 
the DCB control word. 

@ zeros in unused DCB fields. 


The format of the DCB control word for a Seek operation 
is: 
DCB control word 
: Adar key| Modifier bits 
xXx0000)/X X Xjo000010 1. 
1234 


5 7 8 15 
Se, 


| 05 
Reserved 


Reserved 
Input flag 
Reserved 
Chaining flag 


The format of the seek control word (DCB word 1) is: 
Seek control word 


0000xX00xX XxX XK K XK XK X X 
0 3 45 67 


—— 


| = Seek difference 
Reserved 


Seek direction 
Reserved 





— oa 


Set the seek direction bit (bit 4) to 0 to increase the 
cylinder number; set the bit to 1 to decrease the cylinder 
number. Set the nine bits in the seek difference field to 
specify the number of cylinders the movable heads must 
cross to reach the desired cylinder. Set all other bits to 
zero. 


Example: | 
To start from cylinder 10 and seek to cylinder 20, the seek 
control word would be: 


Seek direction 


pone difference 

me" 

0000 0000 0000 1010 
0 0 0 A 


Bit configuration 
Hexadecimal equivalent 


Programming Considerations 


1. To change head selection without moving the heads, 
specify a seek control word of zero and indicate the 
desired head in the head selection field (the high-order 
byte of DCB word 4). 

2. Ifa Seek operation does not execute successfully within 
approximately two seconds, the operation ends imme- 
diately and an interrupt request is sent to the processor. 
At interrupt presentation time, an exception condition 
(CC=2) and an interrupt ID word containing status 
information are presented to the processor. If the seek 
difference specified to reach cylinder 000 is greater 
than required, a seek recalibrate automatically occurs . 
(no error is indicated). 


Seek Recalibrate Operation 


The Seek Recalibrate operation automatically moves the 
access mechanism to cylinder 000 and selects head 0. This 
operation can be used during initialization to return the 
heads to cylinder 000 from an indeterminate location. The 
DCB data associated with a Seek Recalibrate operation, is 
transferred to or from processor storage in cycle steal mode 
and when the disk unit completes the operation an interrupt 
request is sent to the processor. When the processor services 
the interrupt request, a condition code and an interrupt ID 
word are transferred to the processor. Refer to “Interrupts” 
and “Condition Codes” later in this chapter. 

The control information and parameters required for a 
Seek Recalibrate operation must be stored in a DCB. The 
DCB must contain: 


@ a DCB control word that defines a Seek Recalibrate 
operation to the disk unit (DCB word 0). 

@ achain address in DCB word 5 if DCB command chaining 
is specified in the DCB control word for this operation. 
Refer to “DCB Command Chaining” earlier in this 
chapter. 


Although the data in the DCB seek control word (DCB 
word 1) is not needed for this operation, it is checked for 
proper parity. Set unused DCB words and fields to zero. 

The format of the DCB control word for a Seek 
Recalibrate operation is: . 


DCB control word 


Addr key|Modifier bits 
xX 0 0 O7xX X X10 0000111 
2 4 5 7 8 15 
a, 


07 


Reserved 
Reserved 
Input flag 
Reserved 
Chaining flag 


Read Data Operation 


The Read Data operation retrieves a data record stored in 
one or more sectors on the disk and transfers the data into 
contiguous processor storage locations, beginning at the 
data address specified in the DCB. The Read Data operation 
transfers data in cycle steal mode and an interrupt request 
is sent to the processor when the operation ends. 

When the disk unit performs the Read Data operation, the 
head selected with a previous Seek operation immediately 
begins to read the disk for the sector ID specified by the 
search argument in the DCB. When the disk unit locates the 
sector, the information in the data field is transferred from 
the disk to the attachment buffer. The data field is verified 
by recalculating the CRC bytes for the data field and com- 
paring the result with the previously written data field CRC 
bytes. Although the sector being read may not be complete- 
ly filled with data (padded zeros added) the disk unit must 
read to the end of the sector to verify the CRC bytes. Only 


_those bytes specified by the DCB byte count, however, are 


transferred into storage. 

The DCB for a Read Data operation must contain: a 
DCB control word, sector ID search argument (flag, cylinder 
address, head selection, sector number), byte count, and 
data address. Specify the chain address in DCB word 5 and 
set the chaining flag in DCB word 0 to 1 when command 
chaining to another DCB. Set unused DCB words and fields 
to zero. 

The format of the DCB control word for a Read Data 
operation is: 


Control word format (DCB word 0) 


5 7 8 15 
eoememmna, sneer 


09 


Reserved 
Reserved 
Input flag 
Reserved 
Chaining flag 


Programming Considerations 


1. To read more than one sector, set the high-order byte 
of the byte count field (DCB word 6) to indicate the 
number of full sectors to be read. If the last sector is 
only partially filled with data, set the low-order byte 
of the byte count field to indicate the number of data 
bytes in the last sector. If all sectors are filled, set the 
high-order byte to the number of sectors and the low- 
order byte to zero. To read less than one full sector, set 
the high-order byte to zero. Set the low-order byte to 
indicate the number of data bytes to be read. 
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2. Ifa-sector buffer is available for data but the sector ID 
field specified cannot be located after at least one full 
rotation of the disk, the no record found bit (bit 2) in 
cycle steal status word 1 is set to 1. 


Write Data Operation 


The Write Data operation transfers a data record from con- 
tiguous processor storage locations to one or more sectors 
on the disk. When the disk unit executes a Write Data 
operation, data from the DCB specified storage locations 
are transferred in cycle steal mode to the location on the 
disk specified by the search argument in the DCB. An 
interrupt request is presented to the processor when the 
disk unit completes the operation. 

If the last sector being written is not a full sector, the 
disk unit writes the data bytes, then pads the sector to the 
end with zeros. The number of data bytes written for a 
partially-filled sector is determined from the value stored 
in the low-order byte of the DCB byte count (DCB word 6). 

The DCB for a Write Data operation must contain: a 
DCB control word, sector ID search argument (flag, cylinder 
address, head selection, sector number), byte count, and 
data address. Specify the chain address in DCB word 5 and 
set the chaining flag in DCB word 0 to 1 when command 
chaining to another DCB. Set unused DCB words and fields 
to zero. 

The format of the DCB control word for a Write Data 
operation is: . 


DCB contro! word 


Adar key|Modifier bits 
ane eee ee 


OoO12345 7 8 
tee 
Z : 
Reserved 
Reserved 
Input flag 
Reserved 
Chaining flag 


Programming Considerations 


1. To write more than one sector, set the high-order byte 
of the byte count field (DCB word 6) to indicate the 
number of full sectors to be written. If the last sector is 
only partially filled with data, set the low-order byte 
of the byte count field to indicate the number of data 
bytes in the last sector. If all sectors are filled, set the 
high-order byte to the number of sectors and the low- 
order byte to zero. To write less than one full sector, 
set the high order byte to zero. Set the low-order byte 
to indicate the number of data bytes to be written. 
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2. Ifasector buffer is full but the specified sector ID 
field cannot be located after at least one rotation of 
the disk, the no record found bit (bit 2) in cycle steal 
status word 1 is set to 1. 

3. Ifan attempt is made to write more sectors than can 
be contained on a single track, an exception condition 
code (CC=2) dnd the status available bit (bit 0) in the 
ISB are set to,1. The end-of-track bit (bit 0) in cycle 
steal status word 1 is also set to 1. 

4. A data check can occur only on the sector ID field 
when the disk unit is executing a Write Data operation. 
When this occurs, an exception condition code (CC=2) 
is set, the status information available bit (bit 0) in the 
ISB is set to 1, and the file data check and no record 
found bits (bits 3 and 8) in cycle steal status word 1 
are set to 1. The associated data field is not written. 


Read Verify Operation 


The Read Verify operation should be used after each write 
data to validate the previously-written data. The Read 
Verify operation is similar to the Read Data operation. 
Each specified sector is read completely and the Cyclic 
Redundancy Check (CRC) bytes are checked to verify the 
data; however, the data from the disk is not transferred into 
processor storage. When the operation ends, an interrupt 
request is sent to the processor. 

With the exception of the control word (DCB word 0), 
the fields of the DCB for a Read Verify operation should 
be the same as those for the previous write operation. The 
required DCB fields are: control word, sector ID search 
argument (flag, cylinder address, head selection, sector 
number), byte count, and data address. Specify the chain 
address in DCB word 5 and set the chaining flag in DCB 
word 0 to 1 when command chaining to another DCB. Set 
unused DCB words and fields to zero. 

The format of the DCB control word for Read Verify is: 


DCB control word 


Addr key|Modifier bits 
012345 7 8 1B) 
eee, aoa” 
E 00 
Reserved 
Reserved 
Input flag 
Reserved 
' Chaining flag 


Programming Considerations 


1. Ifthe CRC check results in an unequal compare: 

a. an exception condition code (CC=2) is posted 

b. status information is set in the cycle steal status 
words 

c. the status available bit (bit 0) in the ISB is set to 1 
and an interrupt is requested. 

A Start Cycle Steal Status command can then be issued 

to determine the cause of the error. Refer to “Start 

Cycle Steal Status Command” later in this chapter. 

2. Ifthe byte count in the DCB is zero, the operation 
ends immediately, the DCB Specification check bit in 
the ISB is set to 1, and an interrupt request is sent to 
the processor. 


Write Sector ID Operation 


The Write Sector ID operation records sector ID informa- 
tion on the disk at the location specified in the associated 
DCB. The sector ID information is transferred from the 
processor storage location specified in the DCB. The Write 
Sector ID operation transfers data in cycle steal mode and 
causes an interrupt when execution is complete. 

Write Sector ID is a sector counting operation. The physi- 
cal sector count field in the DCB is used to determine where 
the new sector ID should be written. Set the physical sector 
count field to one less than the number of the physical 
sector to be written. Beginning at the index point on the 
track, the sector count is decremented by | each time a 
sector pulse is sensed. When the count reaches zero, the 
sector ID from storage is written in the next sector location 
on the disk. For example, to write a sector ID field for 
sector 3, set the physical sector count to 2 and issue the 
Write Sector ID; the operation works as follows: 


Initial physical sector count = 02 
Sequence of events 


1. Sense index 
2. Sense sector 0 
a. Check for 00 byte count value 
b. Decrement count (minus one) 
3. Sense sector 1 
a. Check for 00 byte count value 
b. Decrement count (minus one) 
4. Sense sector 2 
a. Check for 00 byte count value 
b. Write sector ID field for sector 3 


The DCB for Write Sector ID must contain the following 
fields: control word, physical sector count, byte count 
(must be set to X‘0006’), data address. Specify the chain 
address in DCB word 5 and set the chaining flag in DCB 
word 0 to 1 when command chaining to another DCB. Set 
unused DCB words and fields to zero. 
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The format of the DCB control word for Write Sector ID 
iS: 
DCB control word 
xo ooolxxx|oo 000010) 
XxX 000 0/XXK x10 00000410 
O 123 4 5 7 8 IS 
a 
| 02 

Reserved 

Reserved 

Input flag 

Reserved 

Chaining flag 


The address word (DCB word 7) must point to the loca- 
tion in storage where the five-byte sector ID to be written 
is stored. The five bytes correspond to the flag, cylinder 
address, head selection, and sector number fields in the 
DCB. Refer to “Using the DCB” earlier in this chapter for 
information on specifying values for these fields. The two- 
byte CRC field is written by the disk unit. 


Programming Considerations 


1. Ifthe physical sector byte count is greater than 59, the 
operation ends immediately, a DCB specification check 
is set in the ISB, and an interrupt request is presented 
to the processor. 

2. Acylinder address of 152 must be specified when a 
fixed head is accessed during Write Sector ID, or Write 
Sector ID Skewed operations. The movable heads must 
be positioned over cylinder 152 for every Write Sector 
ID or Write Sector ID Skewed operation performed on 
the fixed heads. The position of the movable heads is 
of no importance for all other fixed head operations. 


Read Sector ID Operation 


The Read Sector ID operation transfers a sector ID from 
the disk into the processor storage location specified by the 


| DCB. Six bytes of information—sync byte (OE), flag, 


cylinder address, head selection, and sector number—are 
transferred. The Read Sector ID operation operates in cycle 
steal mode, and an interrupt request is presented to the pro- 
cessor when the operation is completed. Read Sector ID is a 
sector counting operation. That is, the physical sector byte 
count field in the DCB determines which sector ID should 
be brought into storage. Set the physical sector byte count 
field to one less than the number of the sector to be read. 
Beginning at the index point on the track, the byte count is 
decremented by 1 each time a sector ID field is sensed. 
When the count reaches zero, the next sector ID field is 
read from the disk and transferred into storage. 
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The DCB for Read Sector ID must contain the following 
fields: control word, physical sector count, byte count 
(must be set to X‘0006’), and data address. Specify the 
chain address in DCB word 5 and set the chaining flag in 
DCB word 0 to 1 when command chaining to another DCB. 
Set unused DCB words and fields to zero. 

The format of the DCB control word for Read Sector ID 
is: 


DCB control word 


5 7 8 15 
“a, oe 
| OA 
Reserved 


Reserved 


Input flag 
Reserved 
Chaining flag 


The address word (DCB word 7) must point to the loca- 
tion in storage where the five-byte sector ID from the disk is 
to be stored. The information in the five bytes corresponds 
to the flag, cylinder address, head selection, and sector num- 
ber fields in the DCB. Refer to “Using the DCB” earlier in 
this chapter for information on the content of these fields. 
The two CRC bytes in the sector ID field are not transferred 
into storage. 


Programming Considerations 


If the physical sector byte count is greater than 59, the 
operation ends immediately, a DCB specification check is 
posted in the ISB, and an interrupt request is sent to the 
processor. 


Write Sector ID Skewed Operation 

Write Sector ID Skewed is used to write a sector ID field on 
the disk when a surface defect in the sector ID field prevents 
the successful completion of a Write Sector ID operation. 
Write Sector ID Skewed shifts the sector ID field 64 bytes 
beyond the sector pulse to skip over the surface defect. The 
Write Sector ID Skewed operation destroys part of the data 
field. Before using a Write Sector ID Skewed, use a Read 
Diagnostic operation to recover any data in the defective 
sector. The sector ID that is written should have’bits 6 and 
7 of the flag set to 1 and O respectively, and the cylinder 
address should be set to reflect the address of the alternate 
sector. 

In all other respects, a Write Sector ID Skewed operation 
works the same as a Write Sector ID operation. Data is 
transferred in cycle steal mode and when the data transfer 
is completed, an interrupt request is presented to the 
processor. 
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The DCB for a Write Sector ID Skewed operation must 
contain: a DCB control word, physical sector count, byte 
count (must be set to X‘0006’), and data address. Specify 
the chain address in DCB word 5 and set the chaining flag 
in DCB word 0 to 1 when command chaining to another 
DCB. Set unused DCB words and fields to zero. 

The format of the DCB control word for a Write Sector 
ID Skewed operation is: 


DCB control word 


Adar key| Modifier bits 
X0000}X X XJ0 000001 1] 
0123 4 5 7 8 15 
rl 
| 03 

Reserved 

Reserved 

Input flag 

Reserved 

Chaining flag 


The physical sector count field must be set to one less 
than the number of the sectors to be written. The data 
address word (DCB word 7) must point to the location in 
processor storage where the five-byte sector ID to be written 
on the disk is stored. The five bytes correspond to the flag, 
cylinder address, head selection, and sector number fields in 
the DCB. Refer to “Using the DCB” earlier in this chapter 
for information on specifying values for these fields. 


Programming Considerations 


1. Because it does not leave enough room in the sector for 
a data field, the Write Sector ID Skewed operation must 
only be used for defective sectors. The surface condition 
bit (bit 6) in the flag byte of the sector ID field that is 
written must always be set to 1. 

2. Acylinder address of 152 must be specified when a 
fixed head is accessed during Write Sector ID Skewed 
operations. 


Read Sector ID Skewed Operation 

The Read Sector ID Skewed operation is used to read a 
sector ID that has been written 64 bytes beyond the sector 
pulse by the Write Sector ID Skewed operation. It locates 
the sector ID written 64 bytes past the sector pulse and 


transfers six bytes of sector ID information into the 


processor storage location specified in the data address 
word of the DCB. The Read Sector ID Skewed operation 
is a sector counting operation that transfers data into 
storage in cycle steal mode. When the data transfer ends, 
an interrupt request is sent to the processor. 

Except for searching 64 bytes beyond the sector pulse, 
the Read Sector ID Skewed operation works the same as 
the Read Sector ID operation. 


The DCB for a Read Sector ID Skewed operation must 
contain: a DCB control word, physical sector count, byte 
count (must be set to X‘0006’), and data address. Specify 
the chain address in DCB word 5 and set the chaining flag 
in DCB word 0 to 1 when command chaining to another 
DCB. Set unused DCB words and fields to zero. 

The format of the DCB control word for Read Sector ID 
Skewed is: 


DCB control word 


Adar key| Modifier bits 
X0O100/X XxX xjo 000104141 


O12 3 4 5 7 8 © 15 
a os 
Reserved 
Reserved 
Input flag 
Reserved 
Chaining flag 


The physical sector count field must be set to one less 
than the number of the physical sector to be read. The data 
address word (DCB word 7) must point to the location in 
processor storage where the five-byte sector ID from the 
disk is to be stored. The information in the five bytes 
corresponds to the flag, cylinder address, head selection, 
and sector number fields in the DCB. Refer to “Using the 
DCB” earlier in this chapter for information on the content 


of these fields. The CRC bytes in the sector ID field are not 


transferred into storage. 


Programming Considerations 


This operation should be used when a Read Sector ID opera- 
tion consistently results in a data check or sync check. The 
possibility exists that the sector ID was written 64 bytes 
beyond the sector pulse by a Write Sector ID Skewed 
operation. 


Read Diagnostic Operation 


The Read Diagnostic operation retrieves a data record from 
a sector with a defective sector ID. Read diagnostic is a 
sector-counting operation; it determines the required loca- 
tion on the disk from the physical sector byte count field 
in the DCB. Set the physical sector byte count field (DCB 
word 2) to one less than the sector containing the desired 
data field. Beginning at the index point on the track, the 
byte count is reduced by 1 each time a sector ID is sensed. 
When the count reaches zero, the data field from the next 
sector on the disk is transferred into processor storage. The 
storage location is specified in the data address word (DCB 
word 7). The Read Diagnostic operation transfers data in 
cycle steal mode and requests an interrupt when the opera- 
tion is completed. 
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The DCB for Read Diagnostic operation must contain 
the following fields: control word, physical sector count, 
byte count (must be set to X‘0100’), and data address. 
Specify the chain address in DCB word 5 and set the chain- 
ing flag in DCB word 0 to 1 when command chaining to 
another DCB. Set unused DCB words and fields to zero. 

The format of the DCB control word for a Read Diag- 
nostic operation is: 


DCB control word 


Adar key|Modifier bits 
xX 010 01X X X10 0001000 
0123 4 5 7 8 15 
Se, 
| 08 
Reserved 
Reserved 
Input flag 
Reserved 


Chaining flag 


The address word (DCB word 7) must point to a location 
in storage where the 256 bytes of data are to be stored. 


Programming Considerations 

1. Ifthe physical sector count field is greater than 59, the 
operation ends immediately, a DCB specification check 
is posted in the ISB, and an interrupt request is sent to 
the processor. 

2. Sector ID errors detected during the Read Diagnostic 
operation are ignored. 


Immediate ID Operations 
There are two immediate ID operations: 


e Read sector ID immediate 
e Write sector ID immediate 


Immediate ID operations are time dependent and are in- 
tended to read or write a full track at the maximum rate of 
data transfer. 

To read or write a full track of IDs using an immediate 
ID operation, the program must be in a dedicated mode and 
timing requirements must be adhered to. The timing 
requirements are as follows: 


1. Loop on read diagnostic—sense word 1 testing index 
long (bit 07) for a O condition. 

2. Loop on read diagnostic—sense word 1 testing index 
long (bit 07) for a 1 condition. 
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3. Read or write immediate ID operation—issue either a 
read or write immediate ID operation with 30 DCBs 
chained together. Each DCB is formatted the same as 
a normal read or write ID operation except the physical 
sector count field is not used. The 30 IDs to be read or 
written start with logical sector 01 and continue 
sequentially through ID and end with logical 00. See 
logical sector to physical sector conversion chart below. 

4. Loop on read diagnostic—sense word 1 testing index 
long (bit 07) for a 0 condition. 

5. Read or write immediate ID operation—issue either a 
read or write immediate ID operation with 30 DCBs 
chained together. The 30 IDs to be read or written 
start with logical sector 1F and continue sequentially 
through 3B and end with 1E. See logical sector to 
physical sector conversion chart below. 


Hex conversion of logical sector number to 
physical sector number 
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Start Cycle Steal Status Command 


The Start Cycle Steal Status command transfers four words 
of status information into processor storage beginning at 
the data address location specified in DCB word 7. The 
information in the cycle steal status words can be used to 
determine why the previous command did not execute 
properly. The command operates in cycle steal mode and 
an interrupt request is presented to the processor when the 
operation ends. 

The Start Cycle Steal Status command requires an Oper- 
ate I/O instruction with the address of an IDCB, an IDCB 
with the address of a DCB, and the DCB. The format of the 
IDCB is: 


IDCB (immediate device control block) 


Command field Device address field 
Oo 411i1di1éi%21édi1éi43ixX KX XxX Xx Xi KO XK OX 


0 7 8 IS 
eres Venn tll ~, e 


7F 00—-FF 


Immediate data field 
DCB address 


16 | 31 


The DCB for a Start Cycle Steal Status command must 
contain: a DCB control word, a byte count (must be set to 
X‘0008’), and a data address. The data address specifies the 
storage location into which the four words of status infor- 
mation are to be transferred. All unused DCB words and 
fields must be set to zero. 


The format of the DCB for a Start Cycle Steal Status 
command is: 


DCB (device control block) 


00 1 0 Ofadarkey| 0 0000000 


0 IS 


Word 














Programming Considerations 


1. Ifthe file data check bit (bit 8 of SCSS word 1) is set 
to 1 after a Read Data or Read Verify operation, the 
invalid field can be either the sector ID or the data. The 
sector ID field is invalid if the no record found bit (bit 
3 of SCSS word 1) is also set to 1. The data field is in- 
valid if the no record found bit is set to 0. If the sector 
ID field caused the error and the operation involved 
multiple sectors, any data transferred before the error 
occurred is valid. Refer to the residual address in SCSS 
word 0 to determine the address of the last data word 
transferred into processor storage. 

2. Ifthe file data check bit (bit 8 of SCSS word 1) is set 
to 1 after a Write data operation, an invalid sector ID 
field was detected. When an invalid sector ID is detec- 
ted, the associated data field is not written. If the 
operation involved multiple sectors, the sector number 
the disk unit attempted to write is located in cycle steal 
status word 2. All data fields up to the invalid sector 
will have been written. 

3. The chaining flag in the control word (DCB word 0) 
must be set to 0. DCB command chaining is not sup- 
ported for the Start Cycle Steal Status command. 

4. The disk unit responds ‘busy’ to all commands except 
Prepare, Read Device ID, Device Reset, or Halt 1/O 
from the time a Start Cycle Steal Status command is 
received until an interrupt request is serviced by the 
processor. 


Status Information 

Three types of status information (see Figure 3-9) inform 
the processor of the results of input/output operations: 

e Condition codes 


@ Interrupt ID word 
e@ Cycle steal status information 
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Condition Codes 


Condition codes are posted after execution of each I/O in- 
struction. See Figure 3-8. For commands that do not cause 
interrupts, the condition code reported after the Operate 
I/O instruction executes is the only status information avail- 
able. The appropriate condition code is set in the Even, 
Carry, and Overflow bit positions of the level status register 
(LSR) in the processor. (Refer to “Prerequisite Publications” 
in the Preface of this manual for order number of IBM 
Series/1 processor unit description manuals.) 







Condition Code (CC) Values 
Command | __ Condition Code (CC) Values__—_—_—| 
command eee SS 


CC3 
a 







Start cycle steal status 
cc 


Value Meaning 

0 Device not attached 
1 Busy 

2 Not reported 

3 Command reject 

4 Not reported 

5 Interface data check 
6 Not reported 

7 Satisfactory 


Notes, 

1. If an odd DCB address is stored in the IDCB immediate data field 
for a Start or Start Cycle Steal Status command, a command 
reject condition (CC=3) is reported. 

2. If the disk unit is not ready for operations when a Start com- 
mand is issued, a command reject condition code (CC=3) is 
reported. 

3. Condition code zero (CC=0) is reported if the disk unit is not 
attached to the channel. 


Figure 3-8. Condition code responses to Operate I/O instructions 
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When commands and changing status within the disk 
attachment cause interrupts, a condition code is also trans- 
ferred into the processor LSR at interrupt presentation 
time. The condition code values that can be reported at 
interrupt presentation time are: 


CC Value Meaning 


Not reported 

Not reported 

Exception 

Device end (satisfactory) 
Attention 

Not reported 

Not reported 

Not reported 


NAAN PWN © 


For condition code 2, a second level of status is available 
in the Interrupt Status Byte (ISB) of the interrupt ID word. 
For condition codes 3 and 4, the interrupt status byte con- 
tains binary zeros. 


Interrupt ID Word 


Interrupt status information is transferred to the processor 
in an interrupt ID word. The low-order byte of the interrupt 
ID word contains the address of the interrupting device: the 
high-order byte is an Interrupt Information Byte (IIB). 


Interrupt ID word 


IIB Device address _ 
XX X X X X X X{X X X X X KX X XK 


0 7 8 15 


If commands that cause interrupts fail to end properly 
(CC=2), the IIB has a special format and is called the Inter- 
rupt Status Byte (ISB). 


Interrupt Status Byte (ISB) 


When an interrupt is caused by an exception condition 
(CC=2), the interrupt ID word containing the device address 
and Interrupt Status Byte (ISB) is transferred to the proces- 
sor. The ISB bit meanings are: 


ISB 
bit Meaning 


0 Device Status Available. Additional information about 
the operation is available when this bit is set 1. The 
information is stored in cycle steal status word 1. To 
obtain the information, issue a Start Cycle Steal Status 
command. Refer to “Start Cycle Steal Status Com- 
mand” earlier in this chapter. 

1 Not reported. This bit is always set to 0. 

Not reported. This bit is always set to 0. 

3 DCB Specification Check. If this bit is set to 1, the disk 
operation failed because of an invalid DCB parameter. 
Any of the eight words in the DCB associated with the 
disk operation can set this bit to 1. The residual address 
stored in cycle steal status word 0 points to the DCB 
word containing the invalid parameter. To obtain the 
residual address, refer to “Start Cycle Steal Status 
Command” earlier in this chapter. 

4 Storage Data Check. If data accessed from processor 
storage during a cycle steal output operation is out of 
parity, the operation is terminated and this bit is set 
to 1. A machine check condition does not occur, and 
the parity of the data in that storage location is not 
corrected. If a data storage check occurs, the data in 
the partially filled sector buffer is not written on the 
disk. 

5 Invalid Storage Address. When the storage address 
specified in the DCB is outside the storage capacity 
of processor storage, this bit is set to 1. The bit can 
be set during either an input or output cycle steal 
operation. The operation is terminated immediately. 

6 Protect Check. An attempt to move data into a 
processor storage location using an incorrect cycle 
steal address key sets this bit to 1. The operation is 
terminated immediately. 

7 Interface Data Check. When a parity error is detected 
at the interface this bit is set to 1. The operation is 
terminated immediately. 


Figure 3-9 summarizes the status information available in 
condition codes, in the ISB, and in cycle steal status word 1. 
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Operate I/O Instruction Execution Time 


x8 
= 
n 


Meaning 


Device not attached 
Busy 

Not reported 
Command reject 
Not reported 
Interface data check 
Not reported 
Satisfactory 


NA’NDAALWY = © 


Interrupt Presentation Time 


cc 
Meaning 


Not reported 


Attention 

Not reported 
Not reported 
Not reported 


NAYNNRWN — © 


Interrupt Status Byte 


Bit 
Position Meaning 


Device status available 
Not reported 

Not reported 

DCB specification check 
Storage data check 
Invalid storage address 
Protect check 

Interface data check 


NAMA RWN KH © 


Issue a start cycle steal status command 


Cycle Steal Status Word 1 


Bit 
Position Meaning 


End of track 

Sync check 

Echo check 

No record found 

Write gate check 
Serializer/deserializer check 
PLO out of sync check 
Unsafe 

File data check 

Seek check ._ 

Brake failure 

Write unsafe 

Select unsafe 

Servo unsafe 

Attachment buffer parity check 
Not ready or power off 


Figure 3-9. Status information summary 





aes eat Indicates more information 
Device end (satisfactory) in interrupt status byte (ISB) 


Indicates more information in 
cycle steal status word 1 





Cycle Steal Status Words 


Cycle steal status words containing additional status infor- 
mation are transferred into processor storage by the Start 
Cycle Steal Status command. 


Cycle Steal Status Word 0 


This word contains the residual address. For read operations, 
cycle steal status word 0 contains the processor storage 
address where the last cycle steal of data occurred. For write 
operations, the residual address may be up to four sectors in 
advance of the sector being written on the disk. The residual 
address can be either the address of a word of data or the 
address of a word in the DCB. The residual address is not 
updated during Start Cycle Steal Status command execution. 


Cycle Steal Status Word 1 

Each bit in this word indicates a reason why a normal end- 
of-operation response to the previous Start command did 
not occur. The bits have the following meanings. 


Bit 
Position Meaning 
0 End of track. When at least one but not all of the 


sectors in a multiple sector operation has been trans- 
ferred and the end of the last sector on the track is 
detected, this bit is set to 1. 


1 Sync check. When an unequal comparison for the ‘OE’ 
sync byte at the beginning of either an ID or data field 
occurs, this bit is set to 1. If an ID field caused the 
error, bit 3 of SCSS word 1 is also set to 1. 


2 Echo check. If data sent from the serializer-deserializer 
(serdes) register to the disk does not compare equal to 
the data “‘echoes” resulting from the write operation, 
this bit is set to 1. 

3 No record found. If, after at least one rotation of the 
disk, the disk unit has not found a sector ID that com- 
pares equal to the search argument sector ID, this bit 
is set te 1. 

4 Write gate check. When a sector or index pulse is 
sensed, ‘write gate’ should be inactive. If ‘write gate’ 
is active when a sector or index pulse is sensed, this 
bit is set to 1. 

5 Serializer-deserializer check. If a bit is either lost or 
gained when the parallel channel data is converted to 
serial data during a write operation, this bit is set to 1. 


6 Phase locked oscillator (PLO) out of syne check. When 
the PLO in the disk unit is not synchronized, this bit is 
set to l. 

7 Unsafe. If a malfunction results in an unsafe condition, 


this bit is set to 1. If an unsafe condition exists, read/ 
write and Seek operations are inhibited. An unsafe 
condition indicates that one or more of the unsafe 
conditions (bits 11—13) are present. 


8 File data check. If the CRC bytes that validate each 
sector ID field and data field are in error, this bit is 
set to 1. 

9 Seek check. If a Seek operation fails to.execute 


successfully within approximately two seconds, 
this bit is set to 1. 


10 Brake failure. The brake coil has either opened or 
shorted. 

11 Write unsafe. Write selected and no write transitions 
detected, or write not selected and write current 
detected. 

12 Select unsafe. Write selected and more than one head 
selected. 

13 Servo unsafe. Write selected and heads not on track, or 
write selected and PLO out of sync. 

14 Attachment buffer parity check. If parity is incorrect 


for a word of data from the device buffer during a read 
operation, this bit is set to 0. Words with incorrect 
parity are not transferred into processor storage. 


15 Not ready or power off. When power-up is incomplete 
or the disk unit is (1) not up to rotational speed, (2) 
failed to recalibrate after initial power-up, or (3) is 
unsafe, this bit is set to 1. The unsafe and associated 
not ready condition may be reset with a Device Reset 
or Halt I/O command. 

Notes. 


1. Bits 0 through 6, 8,9, and 14 are reset if the response to the 
next Start command is a condition code of 7 (satisfactory). 

2. Bit 7, bits 10 through 13, and also bit 15 (unless set to 1 by a 
power-on delay) may be reset using a system reset, a power-on 
reset, or Device Reset or Halt I/O command. 


Cycle Steal Status Word 2 


If a write operation ends early because of an error, this 
word identifies the last sector the disk unit attempted to 
write. Bits O through 9 of cycle steal status word 2 are set 
to zero, and bits 10 through 15 are set to indicate the 
sector number. An exception condition code (CC=2) is 
presented at interrupt presentation time. For write opera- 
tions that end normally, the sector number found in bits 

10 through 15 is one greater than the last sector transferred 
to the disk unit. 


Cycle Steal Status Word 3 
This word is reserved. 


1/O Interrupts 


The disk unit can interrupt the processor with two types of 
interrupts: end-of-operation and attention. Before either 
type can interrupt the processor, however, the disk unit 
must be prepared to interrupt. Refer to “Prepare Command” 
described earlier in this chapter. 


Note. Hardware processing of an interrupt includes auto- 
matic branching to a service routine. The processor uses a 
reserved area in storage for branch information. Refer to 
“Prerequisite Publications” in the Preface of this manual. 
Processor description manuals explain reserved storage and 
interrupt handling. 
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End-of-Operation Interrupts 


When an operation initiated by any of the interrupt-causing 
commands ends normally or ends due to an error, an inter- 
rupt request is sent to the processor. The interrupt-causing 
commands are: 


e@ Start 
e@ Start Cycle Steal Status (SCSS) 


The disk unit enters the ‘busy’ state when either com- 
mand is received from the processor. Until the disk unit 
completes an operation initiated by an interrupt-causing 
command, it responds ‘busy’ to all other such commands. 
However, non-interrupting commands (Prepare, Device 
Reset, Read ID, or Halt I/O) are accepted and executed. A 
condition code is reported for all interrupt-causing com- 
mands when the I/O instruction is executed and when the 
interrupt request is serviced by the processor. The first 
condition code indicates whether the command has been 
accepted and the second is transferred to the processor 
with interrupt status information at interrupt presentation 
time. See Figure 3-9. 

Interrupt status information is transferred to the proc- 
essor in an interrupt ID word. The low-order byte of the 
interrupt ID word is the device address; the high-order byte 
is called an Interrupt Information Byte (IIB). If interrupt- 
causing commands fail to end properly (CC=2), the IIB has a 
special meaning and is called an Interrupt Status Byte (ISB). 


Attention Interrupts 


The attention interrupt request is sent to the processor only 
when: 


1. A Prepare command has been issued which allows 
interrupts. 

2. The disk unit is not ‘busy’. 

3. The disk unit has become ‘ready’ (operational). 


Note. When the disk unit goes from ‘ready’ (operational) 
to ‘not ready’ (not operational), an attention interrupt 
request is not sent to the processor. 
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Resets (Disk) 


Several methods of resetting controls and registers are 
available. 


Power-on Reset. Resets: residual address register, prepare 
register, last sector register, data register (16 bits), and cycle 
steal request. 


System Reset. Resets: prepare register, last sector register, 
and cycle steal request. 


Initial Program Load (IPL). Resets: prepare register, last 
sector register, and cycle steal request. 


Halt 1/O Command. Resets: last sector register and cycle 
steal request. 


Device Reset Command. Resets: last sector register. 


Initial Program Load (IPL) 


An Initial Program Load (IPL) operation loads 128 words 
(256 bytes) of control information from cylinder 000, 
sector 00 on the disk into processor storage beginning at 
location zero. The information initializes the processor 
with the program data required to begin operations. Initial 
Program Load operations are hardware initiated only. 

When ‘IPL select’ is received from the processor an auto- 
matic Seek Recalibrate operation selects head 0 and moves 
the access mechanism to cylinder 000. Following the Seek/ 
Recalibrate operation, a Read Data operation with a byte 
count of X‘0100’ (256 decimal) transfers the data from 
sector 00 on the disk into storage. When the IPL sequence 
ends, a device end condition code is presented to the proc- 
essor on interrupt level 0. If an error is detected during the 
IPL sequence, the load indicator on the processor console 
remains on until another attempt to IPL succeeds or a 
system reset/power-on reset occurs. 

The 4962 Disk Storage Unit can be used as either a 
primary or alternate system IPL source. 


Data Security 


If a disk enclosure is removed from a disk unit and returned 
to the factory for any reason (defective, reconfiguration, 
etc.), proprietary information that may be stored on the 
disk is treated in the following manner: 


Data stored on the disk is over- 
written using a single write 
operation on every track. 













Operational 





















Data stored on the disk is over- 
written using a single write 
operation on every track, and 


Disk enclosure is 
defective but the disk is 


ok. 
repairs are made, 


Defective disk The disk is demagnetized and 
destroyed, 


The user is responsible for restoring data on disks returned 
from the factory. 





Fixed Head Data Integrity. Data stored in tracks accessed 
by the eight fixed heads should be refreshed after every 
power-off/power-on cycle. Ambient magnetic fields in the 
vicinity of the disk enclosure should not exceed two gauss. 

If the disk enclosure is removed from the disk unit for 
any reason, the integrity of the data stored on the disk may 
be affected. 
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This chapter describes the I/O commands required to per- 
form input/output operations on the IBM 4964 Diskette 
Unit, and the diskette unit in an IBM 4962 Disk Storage 
Unit Model 2, 2F, and 4. The commands that can be issued, 
the instruction and control blocks required for each com- 
mand, and the individual diskette operation are described. 
Status information and I/O interrupts are also described in 
this chapter. 


Data Transfer Operations 

Data is transferred on the I/O channel in a parallel operation 
(16 data bits plus 2 parity bits). On a write operation, parity 
bits are removed and the data bits are transferred serially to 
the diskette. On a read operation, the data bits are read. 
serially from the diskette, parity bits are added, and the 
information is transferred one word at a time into processor 
storage. The direction in which data moves is determined by 
the I/O command. The command also determines whether 
data moves to or from processor storage under direct pro- 
gram control only, or under direct program control and in 
cycle steal mode. 


Direct Program Control (DPC) 


An I/O command executed under direct program control 
transfers a word of data or control information to or from 
processor storage. After moving the immediate data word, 
the processor continues with other instructions. 


Cycle Steal (CS) 


When data is. transferred in cycle steal mode, processing and 
I/O operations are overlapped. Overlapping allows the proc- 
essor to execute other instructions while the diskette unit is 
cycle stealing the data required to complete the I/O opera- 
tion. Data is transferred by stealing storage cycles from the 
processor. 


Initiating a Diskette Operation 

Every I/O operation to the diskette unit requires (in proces- 
sor storage): 

1. an Operate I/O instruction 


2. an I/O command, device address, and immediate data 
field. 


Chapter 4. Programming Diskette Operations 


Operate I/O Instruction 

The Operate I/O instruction points to an Immediate Device 
Control Block (IDCB) in storage containing an I/O com- 
mand, device address, and immediate data field. Refer to 
“Using the IDCB” later in this chapter. Every Operate I/O 
instruction must have an associated IDCB. 


Note. The Operate I/O instruction is described more com- 
pletely in IBM Series/1 processor unit description manuals. 
Refer to ‘Prerequisite Publications” in the Preface of this 
manual for titles and order numbers. 


The format of the Operate I/O instruction is: 


R2 Functio 
110 0 
8 


n 
10 11 12 I5 


Operate I/O Instruction 


Operation Code 
0141041 
0 


4 5 7 


16 31 


Using the IDCB 


An Immediate Device Control Block (IDCB) must be re- 
served in processor storage for every I/O command issued to 
the diskette unit. Before issuing an Operate I/O instruction 
to the diskette unit, an I/O command and device address 
must be stored in the associated IDCB. The immediate data 
field of the IDCB must contain a data word, a DCB address, 
or zeros. I/O commands that execute only under direct 
program control require a data word or zeros, while com- 
mands that also transfer data in cycle steal mode require 
a DCB address. Refer to “I/O Commands and Diskette 
Operations.” 

The format of the IDCB is: 





IDCB (immediate device control block) 


Command field Device address field 
X X X X X X X X|X X X X X X K X 
0 


7.8 15 
Dann nieemenmene Sammie aati 
OO-FF 
DCB address 0500 
16 31 


Programming Diskette Operations 4-1 


I/O Commands and Diskette Operations 


The I/O command stored in the IDCB determines whether 
a single word of immediate data is transferred under direct 
program control only or, following the DPC operation, 
additional words of data are to be transferred into or from 
processor storage in cycle steal mode. See Figure 4-1. 


Series/1 
instruction 
process 


Operate 1/0 All 1/O commands 


(data word, zeros, or DCB address 











IDCB 
DPC . : 
operation IDCB Device ID (Read Device ID only) 
Condition code response to Operate I/O 
I/O commands that transfer data in cycle 
' steal mode and cause interrupts 
Cycle steal DCB 
DCB 
Cycle 
steal 
. Operations 


Cycle steal data 





Interrupt request 


Interrupt service 


Transfer condition code and Interrupt ID word 


Figure 4-1. Overview of an I/O operation 
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1/0 
device 











Vo 
device 







Command Execution Under Direct 

Program Control 

Prepare, Device Reset, and Read Device ID commands 
transfer a single word of data under direct program control 
to or from the immediate data field of an IDCB in processor 
storage. See Figure 4-2. Command execution is complete 
when a condition code is reported to the processor follow- 
ing the DPC operation. Refer to “Condition Codes” later in 
this chapter. Processing of other instructions resumes when 
the I/O operation ends. 


Operate I/O instruction 


Operation code R2 Function Address 
011041 1100 
0 4 5 7. 8 


101112 15 16 
— 







Effective address 


IDCB (immediate device control block) 


31 


SS, SE 


Immediate data field 


Command field Device address field 
KXXXXXxXxXlOXXXXXXX[ Datalzos 
0 


7 





8 15,16 





LSR 


CCL) aan 


ae ia uf 
Condition code response to DPC operation 


LSR Bit 0 even indicator 
Bit 1 carry indicator 
Bit 2 overflow indicator 


nd 


Data transfer under DPC 








31 








I/O device 







Figure 4-2. I/O operation initiated and executed exclusively under direct program control 


Prepare Command 

Before using any of the interrupt-causing commands, a 
Prepare command must be issued to the diskette unit. The 
Prepare command transfers a word containing interrupt 
parameters from the IDCB immediate data field associated 
with the command to the Prepare Register in the diskette 
attachment. The interrupt parameters in this word establish 
whether the diskette unit is allowed to interrupt, and if so, 


the level on which processing operations can be interrupted. 


The Prepare command is executed under direct program 
control (DPC) and does not cause an interrupt. 


IDCB (immediate device control block) 


Command field Device address field 
01410000 0/0 KX X X XK K X X 


0 7 8 15 
~~, ee ~~, oe 


60 Q0—7F 


Immediate data field 
| eroes i Level | I 


16 26:27 3031 






=interrupts disabled 
1=enable interrupts 


Note, For information about interrupt levels, 
refer to Prerequisite Publications” in the 
Preface of this manual. 
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Device Reset Command 


The Device Reset command resets all pending interrupts 
and previously established control and status conditions. 
The device ID, device address, data address, residual 

_address, and prepare registers are not reset by this com- 
mand. The command code and device address in the IDCB 
supply the information required to execute the Device 
Reset command. Although the IDCB immediate data field 
is not used and not checked, set the bits to zeros. The 
Device Reset command is executed under direct program 

~ control and does not cause an interrupt. 


The format of the IDCB for a Device Reset command is: 


IDCB (immediate device control block) 


Command field Device address field 
Oo 1101321321140 X X X X X KX X 


0 7 8 15 
“Sent, come” See, oe” 


6F 00-—7F 


0000000000000 0 0 0 


16 31 


Read Device ID Command 


The Read Device ID command loads the diskette unit 
device ID word into the immediate data field of the IDCB 
associated with the command. Read Device ID executes 
under direct program control; the device ID is transferred 
immediately into storage, and a condition code is reported 
to the processor. Refer to “Status Information” later in 
this chapter. — 

The format of the IDCB for the Read Device ID com- 
mand is: 


IDCB (immediate device control block) 


Command field Device address field 
001000 0 0j)0 X X XK X XK XK X 
0 7 8 IS 


20 00~—7F 


0000000000 000000 


16 31 
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Before issuing a Read Device ID command, set the IDCB 
immediate data field associated with the command to zero. 
During command execution, the device ID is transferred 
under DPC to this field. After execution of the Read Device - 
ID command, the immediate data field in the IDCB associa- 
ted with the command contains: 


000000010000011 «0 


16 31 
oe nee ete er cal 


X‘0106’ 


Command Execution in CS Mode 

Start and Start Cycle Steal Status commands transfer data 
in cycle steal mode. The DCB address associated with either 
command, however, is transferred under DPC from the 
IDCB immediate data field in processor storage to the 
diskette unit. See Figure 4-3. When the diskette unit 
accepts the command and DCB address, a condition code 
is reported to the processor. The processor continues with 
other operations and the diskette unit begins cycle stealing 
the data required to complete the I/O operation. When the 
transfer of data in cycle steal mode ends, an interrupt 
request is sent to the processor. At interrupt presentation 
time, a condition code and interrupt ID word are trans- 
ferred to the processor. The I/O operation ends and the 
processor continues with other operations. 


Operate I/O instruction 


Operation code Function Address 
; 1 1 0 ; 1100 


Se 12 15 16 31 
Nee, oS 






Effective address 


IDCB (immediate device control block) 
Command field "| Device address field 
X X X X X X X XI]O X X X XK X X OX DCB address 0500 


0 7 8 15 16 31 
Se RR, 9g” 













Data transfer under DPC 


1/O device 


LSR 
ello] 97 
——— 
Condition code response to DPC operation 
LSR Bit 0 even indicator 


Bit 1 carry indicator 
Bit 2 overflow indicator 


Address DCB 


0500 
Cycle steal DCB words 
DCB data 
(8 words) 
I/O device 
Address data area 
0800 
Cycle steal data: 
Data area ee 
Priority interrupt 
Interrupt ID word condition code 


eR ———— oo 
word 


Figure 4-3. I/O operation initiated under direct program control and executed in cycle steal mode 
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Using the DCB 


A Device Control Block (DCB) comprised of eight contig- 
uous processor storage locations must be reserved for every 
I/O operation that transfers data in cycle steal mode and 
causes interrupts. See Figure 4-4. A separate DCB is required 
for: 


@ a Start command 

@ a Start Cycle Steal Status command 

@ all diskette operations included in a DCB command 
chaining sequence (refer to “DCB Command Chaining” 
in this chapter.) _ 


Device parameters that define and control the diskette 
operation must be stored in a DCB. 


d DCB (device control block) 


Wor 
’ 
crews | 








2 


3 





4 





5 | Device parameter word 5 


Data address 


0 ; 15 





6 


7 


Figure 4-4. DCB format (Start command shown) 


General information about each word and field in the 
DCB is supplied in the sections that follow; specific infor- 
mation about each operation is presented later in this 
chapter. a2. ° 


DCB Control Word (DCB Word 0) 


Figure 4-5 shows the format of the DCB control word. This 
word occupies the first position of each DCB associated 
with a Start or Start Cycle Steal Status command. The DCB 
control word delineates the diskette operation. 


DCB control word 


0 
4 678 15 
| er 
Reserved 
- Input flag 
Reserved 
Chaining flag 


Figure 4-5. DCB control word format 
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The meaning of the bits is as follows: i | 
Bit 0 _ Set this bit to 1 to specify DCB command 


(chaining flag) - chaining. When the operation called for by the 
current DCB ends, the chain address stored in 
DCB word 5 points to the next DCB in the 
chained sequence. Refer to “‘DCB Command 
. Chaining” later in this chapter. . 
Bit 1 Set this bit to 0 to avoid future code 
(reserved) obsolescence. 

Bit2 . . Set the input flag bit to 1 for diskette opera- 
(input flag) tions that transfer data into processor storage. | 
‘ . Set the bit to 0 for diskette operations that 

transfer data from storage and for Seek/Seek 
Recalibrate operations. — sa 
Note. If the input flag bit setting is not consis- 
tent with the type of operation, the operation 
-ends and an interrupt request is sent to the 

processor. At interrupt presentation time, an 
exception condition and a DCB specification 
check are presented to the processor. 

Bit 3 Set this bit to 0 to avoid future code 

(reserved) obsolescence. 

Bit 4 Set this bit to 0 to avoid future code 

(reserved) obsolescence. 

Bits 5—7 These bits represent the cycle steal address key 

(address key) required for storage authorization at cycle steal 
request time. 

Bits 8-15 The bits in this field are device dependent 


modifiers of the Start command. A bit con- 
figuration must be selected that represents 

the diskette operation to be performed. The 
selected operation must be compatible with 
the setting of the input flag (bit 2). The hexa- 
decimal designation for each operation and the 
corresponding setting of bit 2 are shown in 
Figure 4-6. 


Note. Burst mode (bit 15) is not supported by 
the 4962 and 4964. 


DCB control word Hexadecimal 


Bit 2 modifier bits8-15 equivalent Operation 

0 00000001 01 Write Data/Data AM 

0 “ 00000010 02 Format Track 

0 00000011 03 ’ Write Data/Control AM 
1 00001001 09 - Read Data 

0 00001100 0c Read Verify 

1 00001010 OA Read Sector ID 

0 00000101 05 Seek 

0 00000111 07 Seek Recalibrate 


Figure 4-6. DCB control word modifier bit configurations 


Seek Control Word (DCB Word 1) 


The seek control word is used, in conjunction with the head 


address specified in the high-order byte of DCB word 4, to 


control the Seek operation. The seek control word specifies 
the direction of the seek—either toward the outer perimeter 
of the diskette or toward its center—and the number of 
cylinders to be crossed. Figure 4-7 shows the format of the 
seek control word. 


Notes. 


1. The seek control word is used only for Seek operations. 


2. If the seek control word is set to zero for a Seek opera- 
tion, no seek movement occurs. 

3. Because they are not required for a Seek operation, set 
DCB word 3, DCB word 6, and the sector number field 
in DCB word 4 to zeros. 


Seek control word 


0000xX0000xXKxXKXXXK XX 


0 34 5 78 9 15 
eee ae ste Sennen, ae 
Seek difference 
Reserved 

Seek direction 
Reserved 


i 


Figure 4-7. Seek control word format 


The meaning of the seek direction and seek difference 
fields are as follows: 


Bit 4 To increase the cylinder number (seek toward 

(seek direction) the center of the diskette), set this bit to 0. To 
seek to a lower cylinder number (toward the 
outer edge of the diskette), set this bit to 1. 


These eight bits specify the seek difference (the 
number of cylinders to be moved). If a seek 
difference of zero is specified, no cylinders are 
crossed and a device end condition is reported 
at interrupt presentation time. 


Bits 8—15 
(seek difference) 


Note. Designating a seek difference beyond 
either physical cylinder limit (00/76) does not 
necessarily place the heads at cylinder 00 or 76. 
The access mechanism may stop in the wrong 
track or between tracks. In either case, an error 
will not be detected until a subsequent read or 
write operation fails to locate the proper sector 
ID. 


Bits 0-3 and 5-7 in the seek control word are reserved; set them 
to 0 to avoid future code obsolescence. 


Format Data Word (DCB Word 2) 


The format data word contains the word of data to be 
written in every word of every sector on a track during a 
Format Track operation. The sector length and cylinder 
fields in DCB word 3 must contain valid values. If the 
sector length byte contains binary 1111 0000, the entire 
track is formatted into 128-byte defective sectors. Refer to 
“Format Track” later in this chapter for more information. 
obsolescence). Refer to “Format Track” later in this 
chapter for more information. 


Sector Length and Cylinder (DCB Word 3) 


DCB word 3 consists of two one-byte fields: the sector 
length and cylinder. 


Sector Length 

The sector length field specifies the length of the sectors on 
the diskette. The field must contain one of the following 
binary values: 


0000 0000 for 128-byte sectors 
0001 0000 for 256-byte sectors 
0010 0000 for 512-byte sectors 
1111 0000 format track defective 


The sector length field corresponds to the N-byte in the 
sector ID on the diskette. It is part of the search argument 
used to locate the required sector. 


Cylinder 

The cylinder field contains a right-adjusted binary number 
from 01—76 that indicates the number of the cylinder con- 
taining the desired sector. If the number specified does not 
fall within the acceptable range (O0—76), the operation 
ends immediately with an exception condition code and a 
DCB specification check is indicated in the ISB at interrupt 
presentation time. 

The cylinder field corresponds to the C-field in the sector 
ID on the diskette. It is used as part of the search argument 
to locate the required sector. On Format Track operations, 
the cylinder specified in this field is written as part of the 
track sector IDs. 


Head Selection and Sector Number (DCB Word 4) 


DCB word 4 consists of two one-byte fields: head selection 
and sector number. 


Head Selection 


The head selection byte specifies which head is to be used 
to access the data. Specify 0000 0000 for head 0; specify 
0000 0001 for head 1 (bits O—6 should be set to zeros to 
avoid future code obsolescence). Specifying any other value 
will result in a ‘no record found’ response to all operations 
except Read Sector ID. 

The head selection byte corresponds to the H-byte in the 
sector ID on the diskette. It is part of the search argument 
used to locate the required sector. 

The head selection byte is used during a Seek operation 
to specify the head to be used for all succeeding data trans- 
fer operations; the head selected can be changed only by 
performing another seek. Seek Recalibrate operations auto- 
matically select head 0 but are not normally used to change 
head selection. 
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Sector Number 

The sector number field contains the number of the specific 
sector to be accessed. The range of valid values depends on 
the sector length specified in the first byte of DCB word 3. 
The valid values for sector length and sector number are: 


Contents of Possible values 


sector length Sector for sector number Decimal 
field (binary) — length field (binary) equivalents 
0000 0000 128 bytes 000000010001 1010 01-26 
0001 0000 256 bytes 00000001 0000 1111 01-15 
0010 0000 $12 bytes 00000001 00001000 01-08 


If the value stored in the sector number byte of DCB 
word 4 exceeds the acceptable range for the sector length 
indicated in the sector length field of DCB word 3, the 
operation ends immediately and an interrupt request is sent 
to the processor. An exception condition code (CC=2) and 
a DCB specification check are transferred to the processor 
at interrupt presentation time. 

The sector number field corresponds to the R-byte in the 
sector ID on the diskette. It is part of the search argument 
used to locate the required sector. 


Chain Address (DCB Word 5) 


To chain operations together, set the chaining flag bit in the 
DCB control word (DCB word 0) to 1. The address of the 
next DCB in the chain must also be specified in DCB word 
5. The address must be an even number. If the chained-to 
address is an odd number (bit 15 is on), the operation ends 
immediately and an interrupt request is sent to the proc- 
essor. An exception condition code (CC=2) and a DCB 
specification check are transferred to the processor at 
interrupt presentation time. 


Byte Count (DCB Word 6) 


The byte count specifies the number of bytes to be trans- 
ferred to or from main storage. The byte count must be an 
even number for all data transfer operations. If bit 15 is 
set on (indicating an odd byte count), the operation ends 
immediately, data is not transferred, and an interrupt is 
requested. An exception condition (CC=2) and a DCB 
specification check in the ISB are transferred to the 
processor at interrupt presentation time. 

The Start Cycle Steal Status command requires a byte 
count of either X‘0004’ or X‘0008’; the Read Sector ID 
operation requires a byte count of X‘0004’. Other data 
transfer operations (Write Data/Data AM, Write Data/ 
Control AM, Read Data, or Read Verify) require a byte 
count that indicates the length of the record to be trans- 
ferred. The byte count is used in conjunction with the 
sector length (N-byte in DCB word 3) to determine the 
number of sectors required for the record. For example, 
if a 134-byte record is to be written, the byte count must 
contain X*°0086’. If the diskette is formatted into 128-byte 
sectors, the N-byte in DCB word 3 would be zero. The 
diskette unit would write 128 bytes of the record into the 
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sector identified in the sector ID search argument; the 

last 6 bytes would be written in the next logical sector, and 
the remainder of the sector would be padded with binary 
zeros. When the record is subsequently read, the padded 
zeros are included in the data field CRC verification. Only 
the number of data bytes specified in the DCB byte count, 
however, are transferred into processor storage. 


Data Address (DCB Word 7) 


This word contains the beginning address of the processor 
storage location used in the data transfer. During a read 
operation, the first word read from the diskette is stored 
in this location; data is transferred to succeeding storage 
locations until the byte count has been fulfilled. During a 
write operation, the word stored at this location is written 
in the first word position of the specified sector; until the 
byte count reaches zero, words from succeeding processor 
storage locations are transferred to the sector location 
specified in the DCB. 

The data address stored in this word must identify a 
storage location that is on an even address boundary. If the 
data address is odd (bit 15 is set to 1), the operation ends 
and an interrupt is requested. At interrupt presentation 
time, a DCB specification check is transferred to the 
processor. Refer to “Interrupts” later in this chapter. 


DCB Command Chaining 


Obtaining a new DCB upon completion of the operation 
specified in the current DCB without issuing a new Operate 
I/O instruction is called DCB command chaining. The DCBs 
belonging to such a sequence are said to be chained. 

When DCBs are chained, the first DCB in the chain con- 
tains the address of the next DCB. As each operation in a 
chained sequence is completed, the chain address in the 
current DCB is used to cycle steal the next DCB in the 
chain. The chained-to DCB is examined to determine the 
next operation in the sequence and whether the device 
parameters associated with it are valid. DCB command 
chaining operations continue until a DCB is fetched that 
has the chain bit in the control word (DCB word 0) set to 
0, indicating the last operation in the chain. If an error 
occurs, chaining to succeeding DCBs is automatically sus- 
pended, and an interrupt request is sent to the processor. 
Normally, an interrupt request is not sent to the processor 
until the diskette unit has completed the last operation in 
the chain. 

DCB command chaining reduces the processing time 
required to execute I/O operations to the diskette unit. 
For example; a single Operate I/O instruction, can: 


seek to a newccylinder location and change head selection 
write a record 

verify that the record was written properly 

seek to a new cylinder location and change head selection 
read a record, etc. 


0e@e6e80 @ 


Start Command 


Start commands initiate I/O diskette operations that trans- 
fer data to or from processor storage in cycle steal mode. 
An interrupt request is sent to the processor when the I/O 
operation ends. An Operate I/O instruction must point to 
an IDCB containing each Start command and the IDCB 
immediate field must contain the address of a DCB. The 
control information and parameters for a particular diskette 
operation must be stored in the DCB associated with that 
operation. Refer to “Using the DCB” earlier in this chapter. 
The diskette operations initiated with a Start command are: 


Seek 

Seek Recalibrate 

Write Data/Data AM 
Write Data/Control AM 
Read Data 

Read Verify 

Read Sector ID 

Format Track 


Note. Refer to the description of each individual diskette 
operation for the format of each DCB control word and for 
programming considerations applicable to each operation. 


When the Operate I/O instruction is issued, the Start 
command is transferred under direct program control from 
the IDCB to the diskette attachment, where it is checked 
for errors and validity. If the command is accepted, a 
‘satisfactory’ condition code (CC=7) is sent to the processor. 
While the diskette unit is ‘busy’ executing the I/O operation, 
the processor continues with other operations. Beginning at 
the DCB address specified in the IDCB, the eight words in 
the DCB are transferred to the diskette unit. The data is 
transferred in cycle steal mode one word at a time. The 
DCB information is decoded and the diskette unit begins 
executing the operation called for in the DCB control word 
(DCB word 0). When the operation (or operations when 
chaining) ends, an interrupt request is sent to the processor. 
At interrupt presentation time, a condition code and inter- 
rupt ID word containing status information are presented 
to the processor. 

The format of the IDCB for a Start command is: 


IDCB (immediate device control block) 


Command field . Device address field 

0111000 0/0 X X X X XK XK X 

0 7 8 15 
Rascommsenennema nema SSE, 
. 70 00-—7F 


Immediate data field 
DCB address 


16 31 


The format of the DCB for a Start command is: 


DCB (device control! block) Word 


Seek control word 

Sector 

length Cylinder 
Chain address 


Data address 


DCB address 
(hexadecimal) 










(+2) 
(+4) 
(+6) 
(+8) 
(+A) 


(+C) 


Programming Considerations 


1. A Seek operation must precede every diskette opera- 
tion that requires a change in either head selection or 
cylinder location. 

2. When DCB command chaining is used to perform 
a series of diskette operations, an interrupt is not 
requested until either an error occurs or the last 
operation in the chained sequence is complete. 

3. To specify DCB command chaining: 

a. For every operation in a DCB command-chained- 
sequence, except the last, set the chaining flag in 
each DCB control word (DCB word 0) to 1. 

b. Set the address of the chained-to DCB in the chain 
address (DCB word 5). 

4. Forevery I/O operation initiated with a Start command 
that is not included in a DCB command-chaining 
sequence, store (in processor storage): 

a. an Operate I/O instruction that points to an IDCB 

b. a Start command with a device address and a DCB 
address in an IDCB 

c. a DCB that contains device parameters and control 
information defining a particular diskette operation 

5. The diskette unit responds ‘busy’ to all commands 
except Prepare, Device Reset, Read ID, or Halt I/O 
from the time the Start command is received until an 
interrupt request is serviced by the processor. 
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Seek Operation 


A Seek operation must precede every I/O operation 
requiring a move of the heads to another cylinder or a 
change in head selection. The Seek operation can be used 
to change: head selection, only; cylinder location, only; 
or both head selection and cylinder location. The DCB 
associated with a Seek operation is transferred to or from 
processor storage in cycle steal mode. An interrupt request 
is sent to the processor when the diskette unit completes 
the operation. A condition code and interrupt ID word 
are transferred to the processor when the interrupt request 
is serviced. Refer to “Interrupts” and “Condition Codes” 
later in this chapter. 

The control information and parameters required for a 
Seek operation must be stored in a DCB. The DCB must 
contain: 


© a DCB control word defining a Seek operation.to the 
diskette unit (DCB word 0). 

© aseek control word that specifies the seek direction and 
number of cylinders to be crossed (DCB word 1). 

@ ahead select byte that specifies which head is to be 
used (high-order byte of DCB word 4). 

© achain address if DCB command chaining is specified i in 
the DCB control word. 

© zeros in unused DCB fields. 


The format of the DCB control word for a Seek spertion 
is: ; 


\ 


DCB control word 


7 8 ; 15 

al 
; 05 | : 

Reserved 

Reserved 

Input flag 

Reserved 

Chaining flag 





The format of the seek control word (DCB word 0) is: 


Seek control word 


0 
~~ _-e’ 


| Seek difference 
Reserved 


Seek direction 
Reserved 


Set the seek direction bit (bit 4) to 0 to increase the 
cylinder number; set the bit to 1 to decrease the cylinder 
number. Set the eight bits in the seek difference field to 
specify the number of cylinders the heads must cross to 
reach the desired cylinder. Set all other bits to zeros. 
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Example: 


To start from cylinder 10 and seek to cylinder 20, the seek 
control word would be: 


, — Seek direction 
| —— Seek difference — 
etiam 

0000 0000 0000 1010 Binary bit configuration 

0 0 0 A Hexadecimal equivalent 

For every Seek operation, the head used to access data 
must be specified in the head selection field of DCB word 
4. Specify binary 0000 0000 for head 0 and 0000 0001 for 
head 1. Bits O—6 should be set to zero to avoid future code 
obsolescence. Specifying any other value results in a no 
record found response. 


Programming Considerations 


1. To change head selection without moving the heads, 
specify a seek control word of zero and indicate the 
desired head in the head selection field (the high-order 
byte of DCB word 4). 

2. Ifa value outside the valid cylinder range (00 through 
76) is set in the seek control word, the heads will not 
necessarily stop at cylinder 00 or cylinder 76. The 
access mechanism might stop anywhere, even between 
tracks. In either case, a failure is not detected until a 
subsequent data transfer operation fails to locate the 
required sector. 

3. The time required to perform a Seek operation can be 
calculated with the following formula: 


— SN+35 milliseconds (head settling time) 
where: 


N = the number of cylinders the head must move 


Seek Recalibrate Operation 


The Seek Recalibrate operation automatically moves the 
access mechanism to cylinder 00 and selects head 0. 
Because a Seek Recalibrate operation requires 0.41 seconds 
to execute, it should only be used in error recovery or 
initialization routines. During a Seek Recalibrate operation, 
no data is transferred to or from processor storage in cycle 
steal mode. An interrupt request is sent to the processor 
when the diskette unit completes the operation. When the 
processor services the interrupt request, a condition code 
and an interrupt ID word are transferred to the processor. 
Refer to “Interrupts” and “Condition Codes” later in this 
chapter. 


The control information and parameters required for a 
Seek Recalibrate operation must be stored in a DCB. The 
DCB must contain: 


e A DCB control word that defines a Seek Recalibrate 
operation to the diskette unit (DCB word 0). 

e@ A chain address in DCB word 5 if DCB command chain- 
ing is specified in the DCB control word for this 
operation. Refer to “DCB Command Chaining” earlier 
in this chapter. 


Although the data in the DCB seek control word (DCB 
word 1) is not needed for this operation, it is checked for 
proper parity. All unused DCB words and fields must be 
set to zero. 

The format of the DCB control word for a Seek Recali- 
brate operation is: 


DCB control word 


Addr key| Modifier bits 
X00 0 0/X X Xj0 0000111 
23 4 


0 1 5 7 8 15 
nl 


| 07 
Reserved 


Reserved 


Input flag 
Reserved 
Chaining flag 


Write data operation 1 


N—Field=0 
Byte Count=128(X‘85’) 


N—Field=0 


Write data operation 2 


Byte Count=178(X‘B2’) 


Write Data/Data AM Operation 


The Write Data/Data AM operation transfers a data record 
from contiguous processor storage locations to one or more 
sectors on the diskette. When the diskette unit executes 

a Write Data/Data AM operation, data from the storage 
location specified in the DCB is transferred in cycle steal 
mode to the location on the diskette specified by the search 
argument in the DCB. The diskette unit automatically 
writes a data address marker (AM) preceding the data in 
each sector written. A data AM indicates that the sector 
contains data. To write a sector of control information, 
refer to ‘Write Data/Control AM Operation” in the next 
section. 

If the sector being written is not a full sector, the 
diskette unit writes the data bytes, then pads the sector to 
the end with zeros. The number of data bytes written is 
determined from the byte count stored in the DCB (DCB 
word 6). Records longer than one sector are written over 
as many sectors as required to satisfy the byte count. 

The DCB for a Write Data/Data AM operation must 
contain: a control word, sector ID search argument (sector 
length, cylinder, head selection, sector number), byte 
count, and data address. Set the chaining flag in DCB word 
0 to 1 and specify a chain address in DCB word 5 when 
command chaining to another DCB. Set unused DCB words 
and fields to zero. 


Write data operation 3 


- N—Field=0 
Byte Count=80(X‘50’) 


padded padded 
ili 128 data bytes | il 128 data bytes ill 50 data bytes Scene lil 80 data bytes ie 


Data AM. Data AM 

CRC CRC 

Sector ID Sector ID 
CRC 


‘Data AM Data AM Data Field CRC 
CRC CRC 

Sector ID Sector ID 

CRC CRC 
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The format of the DCB control word OE a Write Data/ 
Data AM operation is: | 


DCB control word 






Reserved 
Reserved 
Input flag 
Reserved 
Chaining flag 


Programming Considerations 


1. Ifthe sector ID specified in the search argument 
cannot be located after at least one rotation of the 
diskette, or if a sector ID error is detected, the opera- 
tion ends immediately and an interrupt request is sent 
to the processor. An exception condition code (CC=2) 

‘and an interrupt ID word containing status informa- 
tion are transferred to the processor. when the interrupt 
request is serviced. | 

2. The data field of a sector is not written if an error is 
detected in the sector ID. The file data check bit (bit 
07 in cycle steal status word 1) is set to 1 if the sector 
ID contains a CRC error. The sector ID being search 
for could be in cycle steal status words 2 and 3 (refer 
to “Cycle Steal Status Words 2 and 3” later in this 
chapter). Progress on a multiple sector transfer prior 


to detection of the invalid sector ID can be determined ° 


from the residual address in cycle steal status word 0. 
All data fields up to the invalid sector ID will have 
been written. 

3. All Write Data operations Hoi he followed iamede 
ately by a Read Verify operation to validate the data. 

' Refer to “Read Verify Operation” later in this chapter. 

4. Ifa Write Data operation is attempted with the DCB 
command chaining bit set to 0 and a DCB byte count 
of zero, the operation ends after the DCB is fetched, 
and an interrupt request is sent to the processor. A 
device end condition code (CC=3) and an interrupt 
ID word containing accumulated status are transferred 
to the processor when .-the interrupt request is serviced. 

5. The sector length specified in the DCB must be 
consistent with the length of the sectors on the 
diskette. For 128-byte sectors specify X‘00’; for 
256-byte sectors, X‘°10’; and for 512-byte sectors, 
X‘20’. 

6. A Seek operation must precede every Write Data/Data 
AM operation that requires a move of the heads to 
another cylinder or a change in head selection. 
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Write Data /Control AM Operation 


The Write Data/Control AM operation is similar to the 
Write Data/Data AM operation. The only difference 
between the two operations is the address marker that is 
written in the byte immediately preceding each sector data 
field. The Write Data/Control AM operation automatically 
writes X‘F8’ in the AM2 byte, which indicates that the 
data field contains control information. Refer to “Write 
Data/Data AM” for operating details and programming 
considerations. 

The format of the DCB control word for a Write Data/ 
Control. AM is: 


DCB control word 


5 7 8 15 


i 
Reserved 


03 
_ Input flag 
Reserved 


Reserved 





Chaining flag 


Read Verify Operation 


The Read Verify operation should be used after each write 
data to validate the previously-written data. The operation 
is similar to the Read Data operation. Each specified sector 
is read completely and the Cyclic Redundancy Check 
(CRC) bytes are checked to verify the data; however, data 
from the diskette is not transferred to processor storage. 
When the operation ends, an interrupt request is sent to 


. the processor. 


With the exception of the control word (DCB word 0), 
the fields of the DCB for a Read Verify operation should 
be the same as those for the previous write operation. The 
required DCB fields are: control word, sector ID search 
argument (sector length, cylinder, head selection, sector 
number), byte count, and data address. Set the chaining 
flag in DCB word 0 to 1 and specify the chain address in 
DCB word 5 when command chaining to another DCB. Set 
unused DCB words and fields to zero. 

The format of the DCB control word for a Read Verify 
operation is: 


DCB control word - 


Addr key|Modifier bits 
[|x 00 0 ofo 0 ofo 0001100 


0123 4 5 7 8 IS 
Se, ero 
| OC 
Reserved 
Reserved 
Input flag 
Reserved 
Chaining flag 


Programming Considerations 


1. Ifthe CRC check results in an ‘unequal’ compare: 
a. an exception condition code (CC=2) is posted 
b. status information is set in the cycle steal status 

words 

c. the status available bit (bit 0) in the ISB is set to 1 
d. an interrupt request is sent to the processor. 
Issue a Start Cycle Steal Status command, described 
later in this chapter, to determine the cause of the 
error. 

2. Ifthe byte count in the DCB is zero; the operation 
ends immediately, the DCB specification check bit in 
the ISB is set to 1, and an interrupt request is sent 
to the processor. 

3. Read Verify operations do not check for the presence 
of control address markers. 


Read Data Operation 


The Read Data operation retrieves a data record stored in 
one or more sectors on the diskette and transfers the data 
into contiguous processor storage locations, beginning at 
the data address specified in the DCB. The Read Data 
operation transfers data in cycle steal mode and an 
interrupt request is sent to the processor when the opera- 
tion ends. 

When the diskette unit performs the Read Data opera- 
tion, the head selected with a previous Seek operation 
begins immediately to read the diskette surface for the 
sector ID specified by the search argument in the DCB. 
When the sector is located, the data field information is 
transferred into storage in cycle steal mode. The data is 
verified by recalculating the CRC bytes for the data field 
as the data is read from the diskette and comparing the 
result with the previously written data field CRC bytes. 
Although the sector being read may not be completely 
filled with data (padded zeros added), the diskette unit 


must read to the end of the sector to verify the CRC bytes. 


Only those bytes specified by the DCB byte count, 
however, are transferred into storage. 

The DCB for a Read Data operation must contain: a 
DCB control word, sector ID search argument (sector 
length, cylinder address, head selection, sector number), 
byte count, and data address. Set the chaining flag in DCB 
word 0 to 1 and specify a chain address in DCB word 5 
when command chaining to another DCB. Set unused DCB 
words and fields to zero. 


The format of the DCB control word for a Read Data 
operation is: 


Control word format (DCB word 0) 


Addr key| Modifier bits 
X 0 0 OIX X Xj0 000310041 
3 4 5 7 8 15 
~=eoee,_ee 
09 
Reserved 
Reserved 
Input flag 
Reserved 
Chaining flag 


Programming Considerations 


1. Ifasector ID matching the search argument is not 
located after one rotation of the diskette, or if a 
sector ID error is detected, the operation ends 
immediately, and an interrupt request is sent to the 
processor. An exception condition code and interrupt 
ID word containing status information are transferred 
to the processor when the interrupt is serviced. 

2. Amultiple sector read cannot continue beyond a 
sector containing a control address marker (AM). 
When a control AM is detected, the diskette unit reads 
data until the end of the sector containing the control 
AM, ends the operation, and requests an interrupt. 

3. A Seek operation must precede every Read Data 
operation that requires a move of the heads to another 
cylinder or a change in head selection. 


Read Sector ID Operation 

The Read: Sector ID operation is normally used to deter- 
mine which head is selected and on which track the head 
is located. After determining from the DCB control word 
(DCB word 0) that a Read Sector ID operation is called 
for, the diskette unit immediately begins to read data from 
the track under the selected head. The first sector ID 
detected is loaded into a search argument register. The 
register contents (the N, C, H, and R-fields) are transferred 
via cycle steal into processor storage beginning at the data 
address specified in the DCB. 


Note. The high order bits (0Q—3) and low order bits (4—7) 
of the N-byte are interchanged before they are stored. 


When the diskette unit successfully completes the 
operation, an interrupt request is sent to the processor. 
A device end condition code is transferred to the processor 
when the interrupt request is serviced. 
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The format of the DCB control word for a Read Sector 
ID operation is: 


DCB control word 


xX0100i/X X Xl0 0001010 


0123 45 7 8 1S 
a OA 
Reserved 
Reserved 
Input flag 
Reserved 
Chaining flag 


Programming Considerations . 


If a DCB byte count containing any value other than 
X‘0004’ is detected: 


@ the Read Sector ID operation ends immediately 
@ an exception condition (CC=2) is posted 
@ an interrupt request is sent to the processor. 


An exception condition code and an interrupt ID word 
containing a DCB specification check are transferred to 
the processor when the interrupt request is serviced. 


Format Track Operation 


The Format Track operation is normally used to initialize 
a track on the diskette into twenty-six 128-byte sectors, 
fifteen 256-byte sectors, or eight 512-byte sectors. The 
Format Track operation can also be used to identify a 
defective track by initializing the sector IDs with a unique 
data pattern. When 1111 0000 is specified in the DCB 
N-field, the specified diskette track is automatically 
initialized with 128-byte sectors containing one-bits in 
every sector ID on the track. 

The format of the DCB control word for a Format Track 
operation is: 


DCB control word 


Adar key| Modifier bits 
012345 7 8 15 
ounce aoe” 

e 02 

Reserved 

Reserved 

Input flag 

Reserved 

Chaining flag 


X= determined by program requirements 


The DCB for a Format Track operation must contain: 
a DCB control word, a format data word, and a sector 
length and cylinder designation (DCB word 3). 

Set the chaining flag in DCB word 0 to 1 and specify 
a chain address in DCB word 5 when chaining to another 
DCB. Set unused DCB words and fields to zero. 
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Store the data to be repeated for every word, on every 
record, on the track in the DCB format data word. The 
C-byte in DCB word 3 must contain the cylinder address of 
the track. The C-byte value is written in the sector ID 
of each sector formatted on the track. The C-byte value is 
checked for validity: it must be a binary number equal 
to 00 through 76 (decimal). The N-byte in DCB word 3 
specifies the intended size of every sector on the diskette 
track. The N-byte must contain 0000 0000 for 128-byte 
sectors, 0001 0000 for 256-byte sectors, 0010 0000 for 
$12-byte sectors, or 1111 0000 for defective sectors. If 
X‘FO’ is specified in the N-byte, the track is initialized 
with 128-byte sectors containing one bits in every sector 
ID on the track. 


DCB word 3 


0 7 8 15 
ean eee, a 
This byte field contains a 
binary number that represents 
a diskette cylinder location 
(00-76, decimal). 
Binary 


0000 0000=128-byte sectors 
0001 0000=256-byte sectors 
0010 0000=512-byte sectors 
1111 0000=Defective 


Note. Set bits 4—7 to zeros to avoid future code obsolescence. 


Programming Considerations 


1. Every Format Track operation to the diskette unit 
must be preceded by a Seek operation if a change in 
cylinder location or head selection is required. 

2. A Read Sector ID operation can be used to check the 
cylinder location of the heads before each Format 
Track operation is executed. The C-byte value in DCB 
word 3 must specify the logical address of the track 
to be formatted. 

3. Ifan invalid N-field is detected in the DCB associated 
with a Format Track operation, the operation ends 
immediately after the DCB transfer is complete and 
an interrupt request is sent to the processor. A DCB 
specification check (bit 3) is set in the ISB and 
transferred to the processor with an exception condi- 

-tion code when the interrupt request is serviced. The 
N-byte must contain either 0000 0000, 0001 0000, 
00010 0000, or 1111 0000. (Bits 4—7 must be set to 
zeros to avoid future code obsolescence.) 


Start Cycle Steal Status Command 


The Start Cycle Steal Status (SCSS) command transfers 
two or four words of status information into processor 
storage beginning at the data address location specified in 
the DCB. This information is available when the status 
available bit is set to 1 in the ISB at interrupt presentation 
time; the information can determine why the preceding 
I/O operation failed. Refer to “‘Status Information” later 
in this chapter. The SCSS command transfers data in cycle 
steal mode and causes an interrupt when command execu- 
tion is complete. 

The SCSS command requires an Operate I/O instruction 
with the address of an IDCB, and IDCB with the address 
of a DCB, and a DCB. The format of the IDCB is: 


IDCB (immediate device control block) 


Command field Device address field 
0o1i1i1i1éi%21i1«i21«130 KX X X X XX OX 


0 7 8 15 
~~, a, see” 


7F 00-7F 


Immediate data field 


DCB address 
16 31 


The DCB for a SCSS command must contain: a DCB 
control word, a byte count (must be set to either X‘0004’ 
or X‘0008’), and a data address. The data address specifies 
the beginning storage location into which the two or four 
words of status information are to be transferred. The 
SCSS command cannot be included in a DCB command 
chaining operation. Set the chaining flag in the DCB 
control word to 0. Set unused DCB words and fields to 
zero. 

The format of the DCB for the SCSS command is: 


DCB (device control block) 


0 0 1 0 OlAddrkey]}0 0 0000 0 0 


Not used (zeros) 
Not used (zeros) 


Not used (zeros) _ 


Word 









Not used (zeros) 


| Not used (zeros) , 
Byte count 
Data address 
0 IS 






Programming Considerations 


i; 


The Start Cycle Steal Status command cannot be 
included in DCB command chaining operations. The 
SCSS command does not support chaining. 

The no data field found bit (bit 01) in SCSS word 1 
can be caused by a diskette surface defect or a poorly 
written record. 

If the file not ready bit (bit 04) in SCSS word 1 is 

set to 1: a diskette has not been inserted in the 
diskette unit, the diskette has been inserted improperly, 
or the access door has been left open. Bit 04 can be 
set to 1 by other means, but check the above before 
contacting maintenance personnel. 

If the no record found bit (bit 05) is set to 1 after a 
Write Data, Read Verify, or Read Data operation; 
suspect a seek error, track defect, poorly written track, 
or an invalid search argument. 

If the file data check bit (bit 07) is set to 1 after a 
Read Sector ID operation, the search argument in the 
DCB might be invalid. The operation should be 
repeated. 

If the file data check bit (bit 07) in SCSS word 1 is 
set to 1 after a Read Data or Read Verify operation, 
the invalid field can be either the sector ID or the 

data field. The sector ID is invalid if the no record 
found bit (bit 05) in SCSS word 1 is set to 1. The data 
field is invalid if the no record found bit is set to 0. 

If the sector ID caused the error and the operation 


_ involved multiple sectors, any data transferred before 


the error occurred is valid. Refer to the residual 
address in SCSS word 0 to determine the address of 
the last data word successfully transferred into 
processor storage. The most previous sector trans- 
ferred into storage may contain invalid data. 

If the file data check bit (bit 07) in SCSS word 1 is 
set to 1 after a Write Data operation, the diskette unit 
detected an invalid sector ID. The data field associated 
with the invalid sector ID is not written. If the opera- 
tion involved multiple sectors, refer to the residual 
address in SCSS word 0 to determine the address of 
the last data word successfully transferred to the 
diskette surface. All data fields up to the invalid 
sector will have been written. 

The diskette unit responds ‘busy’ to all commands 
except Read Device ID, Prepare, Device Reset or Halt 
I/O from the time it receives the Start Cycle Steal 
Status command until an interrupt request is serviced 
by the processor. 
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9. Ifthe index pulse at incorrect time bit (bit 08) in 
SCSS word 1 is set to 1 after a Read Data or Read 


Verify operation, an index pulse was detected between 


the sector ID and the associated data field. 

10. If the index pulse at incorrect time bit (bit 08) in 
SCSS word 1 is set to 1 after a Format Track opera- 
tion, an index pulse was detected before the track 
initialization operation ended. Suspect a file speed 
error. 


Status Information 


Three types of status information (see Figure 4-9) 
inform the processor of the results of input/output 
operations: 


@ conditions codes 
@ interrupt ID word 
@ cycle steal status words 


Condition Codes 

Condition codes are reported after execution of each 
Operate I/O instruction. See Figure 4-8. For commands 
that do not cause interrupts, the condition code re- 
ported after the Operate I/O instruction executes is the 
only status information available. The appropriate con- 
dition code is transferred into the even, carry, and over- 
flow bit positions of the Level Status Register (LSR) in 
the processor. (Refer to “Prerequisite Publications” in 
the Preface of this manual for order numbers of IBM 
Series/1 processor unit description manuals.) 


CesT ae ae oak rs 


Read device ID 


Start cycle steal status 


cc 

Value Meaning 

0 Device not attached 
1 Busy 

2 Busy after reset 

3 Not reported 

4 Not reported 

5 Interface data check 
6 Not reported 

7 Satisfactory 


Note. Condition code zero (CC = 0) is reported if the diskette unit is not 


attached to the channel or power is off the unit. 


Figure 4-8. Condition code responses to Operate I/O instructions 
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When commands and changing states within the 
diskette attachment cause interrupts, a condition code 
is also transferred into the processor LSR at interrupt 
presentation time. The condition code values that can be 
reported at interrupt presentation time are: 


cc 

value Meaning 

0 Not reported 

1 Not reported 

2 Exception 

3 Device end (satisfactory) 
4 Attention 

SS) Not reported 

6 Not reported 

7 Not reported 


For condition code 2, a second level of status is avail- 
able in the Interrupt Status Byte (ISB) of the interrupt 
ID word. For condition code 3, the Interrupt Informa- 
tion Byte (IIB) contains zeros. Refer to “Interrupt ID 
Word.” For condition code 4, the IIB indicates whether 
a one-sided diskette (X‘80’) or a two-sided diskette 
(X‘00’) is inserted in the unit. 


Note. Hardware processing of an interrupt includes auto- 
matic branching to a service routine. The processor uses 
a reserved area in storage for branch information. Refer 
to “Prerequisite Publications” in the Preface of this 
manual. Processor description manuals explain reserved 
storage and interrupt handling. 


Interrupt ID Word 


Interrupt status information is transferred to the pro- 
cessor in an interrupt ID word. The low-order byte of the 
interrupt ID word contains the address of the interrupt- 
ing device: the high-order byte is an Interrupt Informa- 
tion Byte (IIB). 


Interrupt ID word 


ITB Device address 
X X X X X X X XIO X X X XK XK OX OX 


0 7 8 IS 


If commands that cause interrupts fail to end properly 
(CC=2), the IIB has a special format and is called the 
Interrupt Status Byte (ISB). 


Interrupt Status Byte (ISB) 


When an interrupt caused by an exception condition is 
serviced by the processor, the interrupt ID word con- 
taining the device address and interrupt status byte (ISB) 
is transferred to the processor. The ISB bit meanings are: 


ISB 
bit 
0 


Meaning 


Device status available. Additional information about 
the operation is available when this bit is set to 1. 
The information is stored in cycle steal status word 1. 
To obtain the information, issue a Start Cycle Steal 
Status command. Refer to “Start Cycle Steal Status 
Command” earlier in this chapter. 

Delayed command reject. This bit is set to 1 when an 
error in the Operate I/O instruction is detected. An 
invalid I/O command or an odd DCB address in the 
IDCB can cause this kind of error. 


Not reported. This bit is always set to 0. 


DCB Specification Check. If this bit is set to 1, the 
diskette operation failed because of an invalid DCB 
parameter. Any of the eight words in the DCB associ- 
ated with the diskette operation can set this bit to 1. 
The residual address stored in cycle steal status word 
0 points to the DCB word containing the invalid 
parameter. To obtain the residual address, refer to 
“Start Cycle Steal Status Command” earlier in this 
chapter. 

Storage Data Check. If data accessed from processor 
storage during a cycle steal output operation is out of 
parity, this bit is set to 1. A machine check condition 
does not occur, and the parity of the data in that 
storage location is not corrected. 


Invalid Storage Address. If the storage address speci- 
fied in the DCB is outside the capacity of processor 
storage, this bit is set to 1. This bit can be set to 1: 
during an input or output cycle steal operation. The 
operation ends immediately. 


Protect Check. An attempt to transfer data into a 
processor storage location using an incorrect cycle 
steal address key, sets this bit to 1. The operation 
ends immediately. 

Interface Data Check. If a parity error is detected 

at the interface, this bit is set to 1. The operation 

ends immediately. 


Figure 4-9 summarizes the status information available 
in condition codes, in the ISB, and in the cycle steal 
status words. 
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Operate I/O Instruction Execution Time 








cc 
Meaning 


Device not attached 
Busy 

Busy after reset 
Not reported 

Not reported 
Interface data check 
Not reported 
Satisfactory 


Interrupt Presentation Time 





CC 
Meaning 


Not reported 


aes Na Indicates more information 
in inte tat te (ISB 
Device end (satisfactory) in interrupt status byte (ISB) 


Attention 

Not reported 
Not reported 
Not reported 


Interrupt Status Byte 


Bit 


Position Meaning 


Device status available 
‘Delayed command reject 
Not reported 

DCB specification check 
Storage data check 
Invalid storage address 
Protect check 

Interface data check 


Indicates more information in 
4 cycle steal status word 1 


Issue a start cycle steal status command 





Cycle Steal Status Word 1 
Bit 
Position 
00 


01 
02 


Meaning 


Not used 

No data field found 
Overrun 

Control AM 

File not ready 

No record found 

End of track 

File data check 
Incorrect index time 
Invalid diskette surface 
Not used 

Not used 

Not used 

No erase current 

No write gate 

Erase current stuck on 


Figure 4-9. Status information summary 


Cycle Steal Status Information 

If the diskette unit is not ready when a Start command is 
issued by the processor, or if the diskette unit drops ‘ready’, 
while executing an I/O operation initiated with a Start 
command, an interrupt request is sent to the processor. 

At interrupt presentation time, the status available vit in 
the ISB is set to 1 to indicate that additional status in- 
formation is available. A Start Cycle Steal Status command 
can then be issued to obtain the status information. 


Cycle Steal Status Word 0 


This word contains the residual address; the processor 
storage location where the last cycle steal of data occurred. 
The residual address can be either the address of a word of 
data or the address of a word in the DCB. Execution of the 
SCSS command does not affect this address. 


Cycle Steal Status Word 1 

Each bit used in this word indicates a reason why the a 
normal end-of-operation response to the preceding I/O . 
operation did occur. The bits have the following meanings: 


Bit 

Position Meaning 

00 Not used 

01 No data field found. This bit may be set by a Read 


Data or Read Verify operation. If the bit is set to 1, 
the diskette unit located the correct sector ID but did 
not find the associated data field. 


02 Overrun, During cycle steal transfer operations a 
cycle steal request must be serviced by the processor 
within 48 microseconds or the overrun bit is set on. 
This condition arises when demands for I/O activity 
exceed the capability of the channel. 


03 Control address marker (AM). This bit is set to 1 if, 
during a Read Data operation, a control AM is de- 
tected in front of a sector data field. The operation 
ends after the sector or portion thereof containing 
the control AM has been transferred into processor 
storage. 


Note. A check for the presence of control AMs does 
not occur during Read Verify Operations. 


04 File not ready. If the diskette unit is not ready to 
execute or drops ready while executing a Seek, Seek 
Recalibrate, Write Data, Read Data, Read Verify, 
Read Sector ID, or Format Track operation, this bit 
_ isset to 1. 


05 No record found. If, after at least one rotation of the 
diskette, a sector ID has not been found that com- 
pares ‘equal’ to the search argument sector ID in the 
DCB, this bit is set to 1. If this bit is set to 1 after a 
Read Sector ID operation, it means the diskette unit 
did not locate any sector IDs on the track (suspect an 
unformatted track). 

06 End of track, If at least one but not all of the sectors 
in a multiple sector operation has been transferred and 
the end of the last logical sector on the track is 
detected, this bit is set to 1. 


07 File data check. This bit is set to 1 if a data error is 
detected on the diskette. The CRC bytes, recorded at 
the end of every sector ID and data field, are used for 
error detection. 


08 Index pulse at incorrect time. Refer to ‘Programming 
Considerations” that follow the SCSS command 
description. 

09 Invalid diskette side selected. Two types of diskettes 


are available for use in the diskette unit: one type is 
designed for data storage on only one surface (one- 
sided diskette), and the other type is designed for data 
storage on both surfaces (two-sided diskette). If a 
one-sided diskette is inserted in the diskette unit, head 
0 must be selected for all Seek operations. If head 1 

is specified, the operation ends and the invalid 
diskette side selected bit is set to 1. 


10--12 Not used 


13 No erase current., If this bit is set to 1 after a Write 
Data (Data AM or Control AM) or Format Track 
operation, the data that was written over and the data 
written are probably not retrievable. Retry one 
time only and then call for maintenance. 


14 No write gate. Same as bit 13. 


15 Erase current stuck on. \f this bit is set to 1 after 
any diskette operation, retry one time only and then 
call for maintenance. 


Cycle Steal Status Words 2 and 3 


SCCS words 2 and 3 contain the search argument used in 
the data field access operation that resulted in the inter- 
rupt. The N, C, H, and R-bytes returned in these two 
SCSS words point to the sector location that caused the 
error and ended the operation. The information is only 
useful if the preceding operation was a Write Data, Read 
Verify, or Read Data operation that failed because of a 
data field error. The information is especially useful if the 
I/O operation involved multiple sectors. 


1/O Interrupts 


The diskette unit can interrupt processing with two types 
of interrupts: end-of-operation and attention. Before an © 
interrupt request can be presented to the processor, how- 
ever, the diskette unit must be prepared to interrupt with 
the Prepare command described earlier in this chapter. 


Note. Hardware processing of an interrupt includes auto- 
matic branching to a service routine. The processor uses a 
reserved area in processor storage for branch information. 
Refer to “Prerequisite Publications” in the Preface of this 
manual. Processor description manuals explain reserved 
storage and interrupt handling. 
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If the diskette unit is ‘not ready’ when a Start command 
is issued by the processor, or if the diskette unit drops 
‘ready’, while executing an I/O operation initiated with a 
Start command, an interrupt request is sent to the proces- 
sor. At interrupt presentation time, the status available bit 
in the ISB is set to 1 to indicate that additional status in- 
formation is available. A Start Cycle Steal Status command 
can be issued to obtain the status information. Refer to 
“Start Cycle Status Command” earlier in this chapter. 


End-of-Operation Interrupts 


When an operation initiated by either of the interrupt- 
causing commands ends normally or is terminated by an 
error, an end-of-operation interrupt request is sent to the 
precessor. The interrupt-causing commands are: 


@ Start 
e@ Start Cycle Steal Status (SCSS) 


Until the diskette unit completes an operation initiated 
by an interrupt-causing command, it responds ‘busy’ to 
all other such commands. However, the non-interrupting 
commands (Prepare, Device Reset, Read Device ID, or 
Halt I/O) are accepted and executed. The diskette unit 
reports a condition code when the Operate I/O instruction 
is executed and also when an interrupt request is ser- 
viced by the processor. The first condition code indicates 
whether the command has been accepted; the second con- 
dition code and an interrupt ID word are transferred to the 
processor at interrupt presentation time. 


Attention Interrupt 


An attention interrupt request is sent to the processor for 
only one reason; to notify the processor that the diskette 
unit is ‘ready’ (operational). 

Attention interrupt requests are inhibited during Initial 
Program Load (IPL) operations. If the diskette unit is ‘not 
ready’ when an IPL operation is attempted, a ‘wait’ state 
exists until the diskette unit becomes ready and begins the 
IPL sequence. When the IPL operation ends, an end-of- 
operation request is sent to the processor. At interrupt 
presentation time, a device end condition is reported to the 
processor. If an attention interrupt request is pending when 
an IPL is initiated, the interrupt request is reset. 


Note. An attention interrupt request is not sent to the 
processor when ‘ready’ drops. 
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Resets (Diskette) 


Several methods of resetting controls and registers are 
available. The diskette unit remains ‘busy’ for 200 micro- 
seconds after every reset other than power-on reset. 


Power-on Reset. Resets all controls and registers including 
the prepare register. In addition, head 0 is automatically 
selected, the residual address is reset to X’0001’, and cycle 
steal status word 1 is reset to zero. 


Note. The diskette unit remains ‘busy’ for 12 seconds after 
a power-on reset. This timeout should be taken into 
account especially when auto-IPL is used with the diskette 
unit. 


System Reset. Resets all controls and registers except the 
prepare and residual address registers. 


Initial Program Load (IPL). Resets the prepare register, last 
sector register, and cycle steal request. 


Halt I/O Command. Resets all controls and registers except 
the prepare and residual address registers. 


Device Reset Command. Resets all controls and registers 
except the prepare and residual address registers. 


Initial Program Load (IPL) 


An Initial Program Load (IPL) operation loads information 
from cylinder 00 on the head 0 side of the diskette into 
processor storage beginning at location 0000. The informa- 
tion initializes the processor with the program data required 
to begin operations. Initial program load operations are 
hardware initiated only. 

An ‘IPL select’ signal from the processor to the diskette 
unit produces an automatic Seek Recalibrate operation 
which locates the head access mechanism at cylinder 00 
with head 0 selected. Following the Seek Recalibrate opera- 
tion, an automatic Read Data operation with a byte count 
of X‘0100’ (256 decimal) transfers data from the first two 
sectors following the index into processor storage in cycle 
steal mode. When the IPL sequence ends successfully, a 
device end condition code is presented to the processor on 
interrupt level O at interrupt presentation time. If the IPL 
operation fails, check that the diskette is inserted properly 
in the diskette unit and that the Power On/Off switch is in 
the ON position before attempting another IPL operation. 

The 4964 Diskette Unit can be used as either a primary 
or alternate system IPL source. 


Technical Newsletter This Newsletter No. GN34-0550 


Date August 17, 1979 


Base Publication No. GA34-0024-1 
File No. S1-07 


Previous Newsletters GN34-0406 


IBM Series/1 
4962 Disk Storage Unit and 
4964 Diskette Unit 
Description 


© IBM Corp. 1976, 1977 


This Technical Newsletter provides replacement pages for the subject publication. Pages to be inserted 
and/or removed are: 

iii, iv 

2-1, 2-2 

2-5, 2-6 

3-5 through 3-8 

3-8.1, 3-8.2 (added) 

4-5, 4-6 

4-9 through 4-12 

4-17, 4-18 

X-1 through X-4 

A technical change to the text or to an illustration is indicated by a vertical line to the left of the change. 


Summary of Amendments 
This technical newsletter: 


e Adds information about alternate sector assignment for the 4962 
e Incorporates miscellaneous technical changes 


Note. Please file this cover letter at the back of the manual to provide a record of changes. 


IBM Corporation, Systems Publications, Department 27T, P.O. Box 1328, Boca Raton, Florida 33432 


Printed in U.S.A, 


| is31ME Technical Newsletter This Newsletter No. GN34.0406 


Date October 19, 1977 


Base Publication No. GA34-0024-1 
System —_ Series/1 





Previous Newsletters None 


IBM Series/1 
4962 Disk Storage Unit and 
4964 Diskette Unit 
Description 


©IBM Corp. 1976, 1977 


This Technical Newsletter provides replacement pages for the subject publication. Pages to be inserted 
and/or removed are: 

iii, iv 

1-1 through 1-4 

2-1, 2-2 

3-3, 3-4 

3-7, 3-8 

3-13 through 3-16 

3-16.1, 3-16.2 (added) 


A technical change to the text or to an illustration is indicated by a vertical line to the left of the change. 


Summary of Amendments 
The addition of information pertaining to Models 3 and 4 of the IBM 4962 Disk Storage Unit. 


Note. Please file this cover letter at the back of the manual to provide a record of changes. 


IBM Corporation, Systems Publications, Department 27T, P.O. Box 1328, Boca Raton, Florida 33432 


Printed in U.S.A, 


access times (disk and diskette) 1-3 
address, chain 
disk 3-8 
diskette 4-8 
address, cylinder 
disk 3-7 
diskette 4-7 
address, data 
disk 3-8 
diskette 4-8 
address, invalid storage 
disk 3-17 
diskette 4-17 
address, sector 
disk * 2-2, 3-8 
diskette 2-6, 4-7 
address key, cycle steal 
disk 3-6 
diskette 4-6 
alternate sectors 
assignment of 3-7 
disk 2-2 
diskette 2-4 
attachment buffer (disk) 1-3 
attachment buffer parity check bit, SCSS word 1 
(disk) 3-19 
attachments, disk/diskette 1-3 
attention interrupts 
disk 3-20 
diskette 4-20 


basic data exchange format (diskette) 1-2 
bit configurations, DCB control word modifiers 
disk 3-6 
diskette 4-6 
brake failure bit, SCSS word 1 (disk) 3-19 
buffer, attachment (disk) 1-3 
burst mode, limited support of 3-6, 4-6 
byte, interrupt status (ISB) 
disk 3-17 
diskette 4-17 
byte count (DCB word 6) 
disk 3-8 
diskette 4-8 
bytes per cylinder (disk and diskette) 1-3 
bytes per sector (disk and diskette) 1-3 


C-byte, diskette 2-6 

chain address (DCB word 5) 
disk 3-8 
diskette 4-8 

chaining, DCB command 
disk 3-8 
diskette 4-8 

chaining flag 
disk 3-6 
diskette 4-6 


Page of GA34-0024-1 


As updated August 17, 1979 


By TNL GN34-0550 


Index 


channel overrun 
disk 1-3 
diskette 4-19 
check, file data (diskette) 4-19 
check, interface data 
disk 3-17 
diskette 4-17 
check, protect 
disk 3-17 
diskette 4-17 
check, storage data 
disk 3-17 
diskette 4-17 
codes, condition 
disk 3-16 
diskette 4-16 
command chaining, DCB 
disk 3-8 
diskette 4-8 
command execution in cycle steal mode 
disk 3-4 
diskette 4-4 : 
command execution under direct program control 
disk 3-3 
diskette 4-3 
command reject, delayed (diskette) 4-17 
command reject (disk) 3-16 


commands 

disk 
device reset 3-4 
prepare 3-3 
read deviceID 3-4 
start 3-9 
start cycle steal status 3-15 

diskette 
device reset 44 
prepare 4-3 
read deviceID 4-4 
start 4-9 


start cycle steal status 4-15 
condition codes 
following transfers of data in CS mode 
disk 3-17 
diskette 4-16 
following transfers of data under DPC 
disk 3-16 
diskette 4-16 
control address marker (AM), diskette 2-5, 4-12 
control word, DCB (DCB word 0) 
disk 3-6 
diskette 4-6 
control word, seek (DCB word 1) 
disk 3-6 
diskette 4-6 
controls, operator 1-3 
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count, byte (DCB word 6) 
disk 3-8 
diskette 4-8 
count, physical sector (disk) 3-7 
CRC bytes 
disk 2-2 
diskette 2-6 
CS mode, command execution in 
disk 3-4 
diskette 4-4 
cycle steal address key 
disk 3-6 
diskette 4-6 
cycle steal I/O operation, illustration of 
- disk 3-5 
diskette 4-5 
cycle steal status words (disk) 3-19 
cycle steal status words (diskette) 4-19 
cyclic redundancy check (CRC) 


disk 2-2 

diskette 2-6 
cylinder 

disk 


address 2-2, 3-7 

data capacity 1-3 

description 2-2 
diskette 

address 2-6, 4-7 

description 2-4 


data address (DCB word 7) 
disk 3-8 
diskette 4-8 
data checks 
disk 
interface 3-17 
storage 3-17 
diskette 
interface 4-17 
storage 4-17 
data exchange, basic (diskette) 1-2 
data field (diskette) 
address marker (AM) 2-5 
cyclic redundancy check (CRC) 2-5, 2-6 
data field, immediate 
disk 3-1 
diskette 4-1 
data gap, post (diskette) 2-5 
data security (disk) 3-21 
data storage capacity 
disk 
fixed head 1-3 
movable head 1-3 
diskette 1-3 
data tracks (disk) 2-1 
data transfer operations 
disk 3-1 
diskette 4-1 © 
DCB (device control block) 
disk 
command chaining 3-6 
control word format 3-8 
control word modifier bits 3-6 
format for a SCSS command, illustration 3-16 
format for a start command, illustration 3-9 
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DCB (device control block) (continued) 
diskette 
command chaining 4-6, 4-8 
control word format 4-6 
control word modifier bits 4-6 
format for aSCSS command, illustration 4-15 
format for a start command, illustration 4-9 
device dependent modifier bits 
disk 3-6 
diskette 4-6 
device end 
disk 3-17 
diskette 4-16 
device ID word 
disk 3-4 
diskette 4-4 
device reset command 
description and IDCB format 
disk. 34 
diskette 4-4 
device status available bit 
disk 3-17 
diskette 4-17 
difference, seek 
disk 3-7 
diskette 4-7 
direct program control (DPC) 
disk 3-1, 3-3 
diskette 4-1 
disk/diskette attachments 1-3 
disk operations, I/O commands and 3-2 
disk storage unit . 
functional specifications 1-3 
-models 1-2 
diskette operations, I/O commandsand 4-2 
door, diskette 1-3 
DPC mode, command execution under 
disk 3-3 
diskette 4-3 


echo check bit, SCSS word 1 (disk) 3-19 
Electronic Industries Association rack 1-1 


enclosure 
half-width unit 1-2 . 
4997 1-1 

end-of-operation interrupts 
disk 3-20 


diskette 4-20 
end-of-track bit (SCSS word 1) 

disk 3-19 

diskette 4-19 
error detection capability (diskette) 2-6 
exception conditions (CC=2) 

disk 3-17 

diskette 4-16 


file data check bit (SCSS word 1) 
disk 3-19 
diskette 4-19 
fixed disk 1-1 
flag bits 
alternate sector assignment 3-7 
disk 
chaining 3-6 
input 3-6 
surface condition 3-6 


flag bits (continued) 
diskette 
chaining 4-6 
defective sector (AM2) 2-5 
input 4-6 
format, data word (diskette) 4-7 
format, DCB control words 
disk operations 
read data 3-11 
read diagnostic 3-15 
read sectorID 3-13 
read sector ID skewed 3-15 
read verify 3-12 
seek 3-10 
seek recalibrate 3-11 
write data 3-12 
write sectorID 3-13 
write sector ID skewed 3-14 
diskette operations 
format track 4-14 
read data 4-13 
read sectorID 4-14 
read verify 4-12 
seek 4-10 
seek recalibrate 4-11 
write data/controlAM 4-12 
write data/data AM 4-12 
format, device control block (DCB) 
disk 
start command 3-9 
Start cycle steal statuscommand 3-16 
diskette 
start command 4-9 
start cycle steal status command 4-15 
format, disk surface 2-1 
format, diskette 2-4 
format, immediate device control block (IDCB) 
disk commands 
device reset 3-4 
prepare 3-3 
read deviceID 3-4 
Start 3-9 
Start cycle steal status 3-15 
diskette commands 
device reset 4-4 
prepare 4-3 
read deviceID 4-4 
Start 4-9 
Start cycle steal status 4-15 
format, operate I/O instruction 
disk 3-1 
diskette 4-1 
format track operation (diskette) 4-14 


gaps (diskette) 2-5 


H-byte 2-6 

half-width unit enclosure 1-2 

head selection and sector number (DCB word 4) 
disk 3-7 
diskette 4-7 

hole, index (diskette) 2-3, 2-4 
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I/O commands and disk operations 3-2 
I/O commands and diskette operations 4-2 
I/O interrupts 
disk ° 3-19 
diskette 4-19 
IBM 4959 input/output expansion unit 1-3 
IBM 4962 disk storage unit 1-1 
IBM 4964 diskette unit 1-2 
IBM 4997 rack enclosure 1-1 
ID word, interrupt 
disk 3-17 
diskette 4-16 
IDCB, using the 
disk 3-1 
diskette 4-1 
IDCB format 


disk 
device reset 3-4 
prepare 3-3 
read device ID 3-4 
start 3-9 
start cycle steal status 3-15 
diskette 
device reset 4-4 
prepare 4-3 
read deviceID 4-4 
start 4-9 


start cycle steal status 4-15 

immediate data field, (IDCB) 

diskette 4-1, 4-10 
index, diskette 2-3, 2-4 
index pulse at incorrect time (diskette) 4-19 
indicator, poweron 1-3 
indicators, disk surface condition (flag) 2-2, 3-7 
information byte, interrupt (IIB) 

disk 3-17 

diskette 4-16 
initial program load (IPL) 

disk 1-1, 3-21 

diskette 1-2, 4-20 
initiating a disk operation 3-1 
initiating a diskette operation 4-1 
instruction, operate I/O 

disk 3-1 

diskette 4-1 
interrupts, I/O 

disk 3-19 

diskette 4-19 
invalid diskette side selected 4-19 
invalid N-byte (diskette) 4-14 
invalid storage address 

disk 3-17 

diskette 4-17 


key, cycle steal address 
disk 3-6 
diskette 4-6 


landing zone (LZ), disk 2-1 . 
latency, average rotational delay or 1-2 
level status register (LSR) : 
disk 3-16 
diskette 4-16 
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disk storage unit 1-1. Pos . disk operations (continued) 
diskette unit 1-2 seek 3-11 
modifiers of the start command write data 3-12 
disk 3-6 write sectorID 3-13 
diskette 4-6 — ae . write sector ID skewed 3-13 
movable head data storage capacity diskette commands 
disk 1-3 start 4-9 
diskette 1-3 start cycle steal status 4-15 
diskette operations 
format track 4-14 
N-byte (diskette) 2-6 read data 4-13 
no data field found (diskette) 4-19 read sectorID 4-14 
no record found bit, (SCSS word 1) read verify 4-13 
disk 3-19 seek 4-10 
diskette 4-19 write data/data AM 4-12 
not ready bit (SCSS word 1) protect check 
disk 3-19 disk 3-17 
- diskette 4-19 diskette 4-17 
operate I/O instruction rack, Electronic Industries Association (EIA) 1-1 
disk 3-1 rack enclosure, IBM 4997 1-1 
diskette 4-1 , read data operation 
operator controls 1-3 : ; disk 3-11 
overrun diskette 4-13 
disk 1-3 read device ID operation 
diskette 4-19 ; : ie disk 3-4 
diskette 44 
read diagnostic operation (disk) 3-15 
padded zeros . ; read sector ID operation 
disk 2-2,3-11 = disk 3-13 
diskette 2-3, 4-13 diskette 4-13 : 
parameters, interrupt read sector ID skewed operation (disk) 3-1 
. disk 3-3 read verify operation 
diskette 4-3 disk 3-12 
parameters, seek operation diskette 4-12 
disk 3-6 resets 
diskette 4-7 Bt disk 3-20 
phase locked oscillator (PLO) out of sync check . diskette 4-20 , 
(disk) 3-19 rotational delay or latency, average (disk) 1-3 
physical sector count and flag, DCB word 2 (disk) 3-7 . rotational speed 
post-data gap (diskette) 2-5 disk 1-3 
post-ID gap (diskette) 2-5 diskette 1-3 


post-index gap (diskette) 2-5 
power onindicator 1-3 


power on reset sector address (disk) 2-2, 3-8 
disk 3-20 sector assignment, alternate 3-7 
diskette 4-20. sector count, physical (disk) 3-7 

pre-index gap (diskette) 2-5 ; sector format 

prepare command Le disk 2-2 
disk 3-3 diskette 2-5 
diskette 4-3 3 sector ID format 

programming considerations disk 2-2 
disk commands diskette 2-6 

start 3-10 sector length and cylinder, DCB word 3 (diskette) 4-7 
start cycle steal status 3-16 sector number, DCB word 4 
disk operations disk 3-7 
read data 3-11 diskette 4-7 
read diagnostic 3-15 sectors per track 
read sectorID 3-14 disk 1-3, 2-2 
read sector ID skewed 3-15 . diskette 2-4 
read verify 3-13 , 4 ad seek check bit (disk) 3-19 
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seek control word, DCB word 1 
disk 3-6 
diskette 4-7 
seek direction and seek difference 
disk 3-7 
diskette 4-7 
seek operation _ 
disk 3-10 
diskette 4-10 
seek recalibrate operation 
disk 3-11 
diskette 4-10 
select unsafe bit, SCSS word 1 (disk) 3-19 
selection, head (disk) 3-7 
serializer-deserializer check bit, SCSS word 1 
(disk) 3-19 
servo tracks (disk) 2-1 
servo unsafe bit, SCSS word 1 (disk) 3-19 
specification check, DCB 
disk 3-17 
diskette 4-17 
specifications, functional 
disk 1-2 
diskette 1-3 
speed, rotational 
disk 1-2 
diskette 1-3 
start command 
disk 3-9 
diskette 4-9 
start cycle steal status command 
disk 3-15 
diskette 4-15 
Start time 1-3 
status byte, interrupt (ISB) 
disk 3-17 
diskette 4-17 
status information 
disk 3-16 
diskette 4-16 
status words, cycle steal 
disk 3-19 
diskette 4-19 
storage address, invalid 
disk 3-17 
diskette 4-17 
storage data check 
disk 3-17 
diskette 4-17 
surface condition indicators (disk) 2-2, 3-7 
surface format 
disk 2-1 
diskette 2-4 
switch, power on/off 1-3 
sync check bit, SCSS word 1 (disk) 3-19 
system reset 
disk 3-20 
diskette 4-20 


track capacity 
disk 1-3 
diskette 2-4 


track format 

disk 2-1, 2-2 

diskette 2-5 
tracks, data 

disk 2-1 

diskette 2-4 
tracks, servo (disk) 2-1 
tracks per cylinder 

disk 1-3, 2-2 

diskette 2-4 


unsafe bit, SCSS word 1 (disk) 3-19 
using the DCB 

disk 3-6 

diskette 4-6 
using the IDCB 

disk 3-1 

diskette 4-1 


write data/control AM operation (diskette) 4-12 
write data/data AM operation (diskette) 4-11 
write data operation (disk) 3-12 

write gate check bit, SCSS word 1 (disk) 3-19 
write sector ID operation (disk) 3-13 

write sector ID skewed operation (disk) 3-14 
write unsafe bit, SCSS word 1 (disk) 3-19 


zone (LZ), landing 2-1 
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